国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 web前端 html教程 DIV+CSS:不用表格的菜單_html/css_WEB-ITnose

DIV+CSS:不用表格的菜單_html/css_WEB-ITnose

Jun 24, 2016 pm 12:29 PM

布局初步搭建起來,我開始填充里面的內(nèi)容。首先是定義logo圖片:

樣式表:#logo {MARGIN: 0px;padding:0px;WIDTH: 200px;HEIGHT:80px;}
頁面代碼:


以上代碼現(xiàn)在應(yīng)該容易理解。先在CSS定義了一個logo的層,然后在頁面中調(diào)用它。需要說明的是,為了使網(wǎng)頁有更好的易用性,web標準要求大家給所有的、屬于正式內(nèi)容的圖片,加一個alt屬性。這個alt屬性是用來說明圖片的作用(當圖片不能顯示的時候就顯示替換文字),所以不要只寫成無意義的圖片名稱。

接下來是定義菜單。

1.不用表格的菜單(縱向)
我們先來看菜單的最終效果:

什么是網(wǎng)站標準
使用標準的好處
怎樣過渡
相關(guān)教程
工具
資源及鏈接

通常方法我們至少嵌套2層表格來實現(xiàn)這樣的菜單,間隔線采用在td中設(shè)置背景色并插入1px高的透明GIF圖片實現(xiàn);背景色的交替效果采用td的onmouseover事件實現(xiàn)。但查看本菜單的頁面代碼,你會看到只有如下幾句:


沒有用任何table,而用的是無序列
  • ,整個菜單的效果實現(xiàn)的秘密完全在于id="menu",我們再來看CSS中關(guān)于menu的定義:

    (1)首先定義了menu層的主要樣式:

    #menu {
    MARGIN: 15px 20px 0px 15px; /*定義層的外邊框距離*/
    PADDING:15px; /*定義層的內(nèi)邊框為15px*/
    BACKGROUND: #dfdfdf; /*定義背景顏色*/
    COLOR: #666; /*定義字體顏色*/
    BORDER:#fff 2px solid; /*定義邊框為2px白色線條*/
    WIDTH:160px; /*定義內(nèi)容的寬度為160px*/
    }
    (2)其次定義無序列表的樣式:

    #menu ul {
    MARGIN: 0px;
    PADDING: 0px;
    BORDER: medium none; /*不顯示邊框*/
    LINE-HEIGHT: normal;
    LIST-STYLE-TYPE: none;

    }
    #menu li {BORDER-TOP: #FFF 1px solid; MARGIN: 0px;}
    說明:這里用的是id選擇器的派生方法定義(參考第7天:CSS入門的介紹)了在menu層中的子元素
    • 的樣式。LIST-STYLE-TYPE: none一句表示不采用無序列表的默認樣式,即:不顯示小圓點(我們后面用自己的圖標來代替小圓點)。BORDER-TOP: #FFF 1px solid;則定義了菜單之間的1px間隔線。

      (3)定義onmouseover效果

      #menu li a {
      PADDING:5px 0px 5px 15px;
      DISPLAY: block;
      FONT-WEIGHT: bold;
      BACKGROUND: url(/bok/images/icon_dot_lmenu.gif) transparent no-repeat 2px 8px;
      WIDTH: 100%;
      COLOR: #444;
      TEXT-DECORATION: none;
      }
      #menu li a:hover { BACKGROUND: url(/bok/images/icon_dot_lmenu2.gif) #C61C18 no-repeat 2px 8px;
      COLOR: #fff; }
      解釋如下:

      "display:block;"表示將標簽a當作塊級元素來顯示,使得鏈接變成一個按鈕;
      "BACKGROUND: url(/bok/images/icon_dot_lmenu.gif) transparent no-repeat 2px 8px;"這一句定義了替代li的小圓點的圖標。"transparent"指背景為透明,"2px 8px"指定圖標的位置是距左邊2px,距上邊8px。這一句也可以拆分寫成四句:"BACKGROUND-IMAGE: url(/bok/images/icon_dot_lmenu.gif); BACKGROUND-POSITION: 2px 8px; BACKGROUND-REPEAT: no-repeat; BACKGROUND-COLOR: transparent;"
      "#menu li a:hover"定義了當鼠標移動到鏈接上以后的顏色變化和小圖標變化。
      ok,不用表格的菜單就這樣實現(xiàn)了。大家可以明顯感覺到,原來寫在HTML里的表現(xiàn)樣式全部剝離放到CSS文件里去了。頁面代碼節(jié)約了大半。通過CSS要修改菜單樣式就很簡單了。

      2.不用表格的菜單(橫向)
      上面是縱向的菜單,如果要顯示橫向菜單,用li也可以嗎?當然是可以的,下面給出代碼,效果就在本頁頂部:

      頁面代碼


      樣式表代碼

      #submenu {
      MARGIN: 0px 8px 0px 8px;
      PADDING: 4px 0px 0px 0px;
      BORDER: #fff 1px solid;
      BACKGROUND: #dfdfdf;
      COLOR: #666;
      HEIGHT:25px; }

      #submenu ul {
      CLEAR: left;
      MARGIN: 0px;
      PADDING:0px;
      BORDER: 0px;
      LIST-STYLE-TYPE: none;
      TEXT-ALIGN: center;
      DISPLAY:inline;
      }

      #submenu li {
      FLOAT: left;
      DISPLAY: block;
      MARGIN: 0px;
      PADDING: 0px;
      TEXT-ALIGN: center}

      #submenu li a {
      DISPLAY: block;
      PADDING:2px 3px 2px 3px;
      BACKGROUND: url(/bok/images/icon_dot_lmenu.gif) transparent no-repeat 2px 8px;
      FONT-WEIGHT: bold;
      WIDTH: 100%;
      COLOR: #444;
      TEXT-DECORATION: none;
      }

      #submenu li a:hover {
      BACKGROUND: url(/bok/images/icon_dot_lmenu2.gif) #C61C18 no-repeat 2px 8px;
      COLOR: #fff; }

      #submenu ul li#one A { WIDTH: 60px}
      #submenu ul li#two A { WIDTH: 80px}
      #submenu ul li#three A { WIDTH: 80px}
      #submenu ul li#four A { WIDTH: 90px}
      #submenu ul li#five A { WIDTH: 80px}
      #submenu ul li#six A { WIDTH: 80px}
      #submenu ul li#seven A { WIDTH: 60px}
      #submenu ul li#eight A { WIDTH: 90px}
      #submenu ul li#nine A { WIDTH: 80px}

      以上代碼不逐一分析了。橫向菜單的關(guān)鍵在于:定義
    • 樣式時的"FLOAT: left;"語句。另外注意UL定義中的DISPLAY:inline;一句表示將li強制作為內(nèi)聯(lián)對象呈遞,從對象中刪除行,通俗講就是li不換行。實現(xiàn)橫向排列。你也可以象例子中定義每個子菜單的寬度,控制菜單的間隔。好了,你也可以動手試試,用li實現(xiàn)各種各樣的菜單樣式。

      Tips:如果你子菜單的寬度總和大于層的寬度,菜單會自動折行,利用這個原理可以實現(xiàn)單個無序列表的2列或者3列排版,這是原來HTML很難實現(xiàn)的。
  • 本站聲明
    本文內(nèi)容由網(wǎng)友自發(fā)貢獻,版權(quán)歸原作者所有,本站不承擔相應(yīng)法律責任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請聯(lián)系admin@php.cn

    熱AI工具

    Undress AI Tool

    Undress AI Tool

    免費脫衣服圖片

    Undresser.AI Undress

    Undresser.AI Undress

    人工智能驅(qū)動的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用于從照片中去除衣服的在線人工智能工具。

    Clothoff.io

    Clothoff.io

    AI脫衣機

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的代碼編輯器

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    禪工作室 13.0.1

    禪工作室 13.0.1

    功能強大的PHP集成開發(fā)環(huán)境

    Dreamweaver CS6

    Dreamweaver CS6

    視覺化網(wǎng)頁開發(fā)工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神級代碼編輯軟件(SublimeText3)

    我如何了解最新的HTML標準和最佳實踐? 我如何了解最新的HTML標準和最佳實踐? Jun 20, 2025 am 08:33 AM

    要跟上HTML標準和最佳實踐,關(guān)鍵在于有意為之而非盲目追隨。首先,關(guān)注官方來源如WHATWG和W3C的摘要或更新日志,了解新標簽(如)和屬性,將其作為參考解決疑難問題;其次,訂閱可信的網(wǎng)頁開發(fā)新聞通訊和博客,每周花10-15分鐘瀏覽更新,關(guān)注實際用例而非僅收藏文章;再次,使用開發(fā)者工具和linters如HTMLHint,通過即時反饋優(yōu)化代碼結(jié)構(gòu);最后,與開發(fā)者社區(qū)互動,分享經(jīng)驗并學習他人實戰(zhàn)技巧,從而持續(xù)提升HTML技能。

    如何使用元素來表示文檔的主要內(nèi)容? 如何使用元素來表示文檔的主要內(nèi)容? Jun 19, 2025 pm 11:09 PM

    使用標簽的原因是提升網(wǎng)頁的語義化結(jié)構(gòu)和可訪問性,使屏幕閱讀器和搜索引擎更易理解頁面內(nèi)容,并允許用戶快速跳轉(zhuǎn)至核心內(nèi)容。以下是關(guān)鍵要點:1.每個頁面應(yīng)僅包含一個元素;2.不應(yīng)包括跨頁面重復的內(nèi)容(如側(cè)邊欄或頁腳);3.可與ARIA屬性結(jié)合使用以增強無障礙體驗。通常位于和之后、之前,用于包裹唯一的頁面內(nèi)容,例如文章、表單或產(chǎn)品詳情,并應(yīng)避免嵌套在、或中;為提高輔助功能,可使用aria-labelledby或aria-label明確標識部分。

    如何最小化HTML文件的大小? 如何最小化HTML文件的大??? Jun 24, 2025 am 12:53 AM

    要減小HTML文件大小需清理冗余代碼、壓縮內(nèi)容并優(yōu)化結(jié)構(gòu)。 1.刪??除未使用的標簽、注釋和多余空白以減少體積;2.將內(nèi)聯(lián)CSS和JavaScript移至外部文件并合并多個腳本或樣式塊;3.在不影響解析的前提下簡化標簽語法,如省略可選閉合標簽或使用簡短屬性;4.清理后啟用Gzip或Brotli等服務(wù)器端壓縮技術(shù)進一步縮減傳輸體積。這些步驟可在不犧牲功能的前提下顯著提升頁面加載性能。

    如何創(chuàng)建基本的HTML文檔? 如何創(chuàng)建基本的HTML文檔? Jun 19, 2025 pm 11:01 PM

    要創(chuàng)建一個基本的HTML文檔,首先需要了解其基本結(jié)構(gòu)并按照標準格式編寫代碼。1.開始時使用聲明文檔類型;2.使用標簽包裹整個內(nèi)容;3.在其中包含和兩個主要部分,用于存放元數(shù)據(jù)如標題、樣式表鏈接等,而則包含用戶可見的內(nèi)容如標題、段落、圖片和鏈接;4.保存文件為.html格式并在瀏覽器中打開查看效果;5.隨后可逐步添加更多元素以豐富頁面內(nèi)容。遵循這些步驟即可快速構(gòu)建一個基礎(chǔ)網(wǎng)頁。

    如何使用 如何使用 Jun 19, 2025 pm 11:41 PM

    要創(chuàng)建HTML復選框,需使用type屬性設(shè)為checkbox的元素。1.基本結(jié)構(gòu)包含id、name和label標簽,確保點擊文字可切換選項;2.多個相關(guān)復選框應(yīng)使用相同name但不同value,并用fieldset包裹提升可訪問性;3.自定義樣式時隱藏原生控件并用CSS設(shè)計替代元素,同時保持功能完整;4.確??捎眯?,配對label、支持鍵盤導航且避免僅依賴視覺提示。以上步驟能幫助開發(fā)者正確實現(xiàn)兼具功能與美觀的復選框組件。

    如何使用元素代表文檔或部分的頁腳? 如何使用元素代表文檔或部分的頁腳? Jun 25, 2025 am 12:57 AM

    是HTML5中用于定義頁面或內(nèi)容區(qū)塊底部的語義化標簽,通常包含版權(quán)信息、聯(lián)系方式或?qū)Ш芥溄拥?;它可置于頁面底部或嵌套在、等標簽?nèi)作為區(qū)塊尾部;使用時應(yīng)注意避免重復濫用及放入無關(guān)內(nèi)容。

    隨著時間的流逝,HTML如何發(fā)展,其歷史上的關(guān)鍵里程碑是什么? 隨著時間的流逝,HTML如何發(fā)展,其歷史上的關(guān)鍵里程碑是什么? Jun 24, 2025 am 12:54 AM

    htmlhasevolvedscreatscreationtomeetthegrowingdemandsofwebdevelopersandusers.inatelyallyasimplemarkuplanguageforsharingdocuments,ithasundergonemajorupdates,包括html.2.0,包括wheintrodistusefforms;

    如何使用Tabindex屬性來控制元素的選項卡順序? 如何使用Tabindex屬性來控制元素的選項卡順序? Jun 24, 2025 am 12:56 AM

    ThetabindexattributecontrolshowelementsreceivefocusviatheTabkey,withthreemainvalues:tabindex="0"addsanelementtothenaturaltaborder,tabindex="-1"allowsprogrammaticfocusonly,andtabindex="n"(positivenumber)setsacustomtabbing

    See all articles