<strike id="cy2gs"><menu id="cy2gs"></menu></strike>
  • <del id="cy2gs"><dfn id="cy2gs"></dfn></del>
  • css對邊框的屬性控制和鏈接的偽類選擇器

    2020-2-3    seo達人

    邊框(border): css控制的邊框屬性包括border-width, border-color, border-style.



    Border之所以讓人很困惑主要源于IE5錯綜復雜的BUG, 由于IE5是一個“will soon be dead” 的瀏覽器, 這里只例舉一個最為知名的關于border-width的BUG, 讓大家更好的理解border的含義, 先看下圖:







    如上圖所示, 對象A(白色矩形)周圍有藍色邊框B, 可以看出A的實際寬度為ef, 而IE5不這么認為, 它把cd的長度定義為對象A的寬度, 這個bug在邊框的寬度小時幾乎察覺不到, 但在邊框與對象寬度相差不大時顯得尤為明顯.



    新建一個前端學習qun438905713,在群里大多數都是零基礎學習者,大家相互幫助,相互解答,并且還準備很多學習資料,歡迎零基礎的小伙伴來一起交流。



    現在, 結合以上說明, 可以看出border是獨立于對象之外, 位于magin與padding之間(后說明), 具有固定寬度, 顏色和樣式的區域.


    1. border-width: 其可有具體數值(如1px, 2px等)或是描述性(thin, medium, thick)的屬性值. 由于瀏覽器及個人設置的不同導致thin, medium, thick這些屬性值的表現不一, 不推薦使用. css代碼如下:



      border-width: 1px;

      border-width: 2px;

      border-width: thin;

      border-width: medium;

      border-width: thick;



      寬度效果如下(注意不同瀏覽器下的區別):



       1px    2px    thin    medium    thick 


    2. border-style: 邊框樣式包括solid, dashed, dotted, double, groove, ridge, inset, outset等, 代碼如下:



      border-style: solid;

      border-style: dashed;

      border-style: dotted;

      border-style: double;

      border-style: groove;

      border-style: ridge;

      border-style: inset;

      border-style: outset;



      樣式效果如下(你可能需要Firefox或是Opera才能看到后四種效果):



       solid   



       dashed   



       dotted   



       double   



       groove   



       ridge   



       inset   



       outset   


    3. border-color: 邊框顏色屬性和一般顏色屬性是一樣的, 可以參看屬性篇(1).



      Summary: 以上例舉的都是四邊相同樣式的情況, 其實可以分別設置border-top, border-right, border-bottom, border-left四邊的屬性, 比方說想要表現一個寬2px, 藍色(blue), 樣式為solid的上下邊框, 代碼如下:



      border-top-width: 2px;

      border-top-color: blue;

      border-top-style: solid;

      border-bottom-width: 2px;

      border-bottom-color: blue;

      border-bottom-style: solid;



      簡寫為:



      border-top: blue 2px solid;

      border-bottom: blue 2px solid;



      表現如下:



       寬2px,藍色,樣式為solid的邊框 



      鏈接(link): 在html里用<a></a>標明鏈接, 在css里用a作為鏈接的選擇器名.



      css的缺點和它的優點一樣明顯, 其最大的缺陷就在于網頁的動態表現不足, 在這一點上和Flash差距尤為突出.



      好在css還是留了一手, 那就是鏈接的偽類選擇器, 所謂偽類就是指依賴于瀏覽器或是用戶的狀態. 對于鏈接來講, 存在link, hover, visited, active四種狀態, 即四種偽類選擇器: a:link(存在鏈接, 但無鼠標動作), a:visited(被點擊或訪問過), a:hover(鼠標懸停于鏈接上時的狀態), a:active(鼠標點擊與釋放之間的狀態).



      css便是以這幾個偽類選擇器實現了其為數不多的動態效果. 目前最為常用的就是導航條和按鈕的動態顯示. 以下用一個動態按鈕的實例來說明這四個偽類選擇器.


    4. 首先準備一副圖片(button.png), 如下圖(160px240px), 其由四幅160px60px的小圖自上而下排列而成.



       






    5. 接著需要往你的本地調試文件夾(調試環境的建立方法參考屬性(1)中的說明)的index.htm中寫入html代碼, 如下:



      <div id=”button”><a href=”#”></a></div>


    6. 在style.css中寫入以下代碼:



      body {background-color: #FFF;}

      button a{

      width:160px;

      height:60px;

      display:block;

      background:url(../image/button.png) no-repeat 0 0;


      button a:link { background-position:0 0;}

      button a:hover { background-position:0 -60px;} 

      button a:active { background-position:0 -120px;}

      button a:visited { background-position:0 -180px;}



      可以看到如 Example2 的效果.


    7. 代碼解釋:



      <div id=”button”><a href=”#”></a></div>



      在index.htm寫入如上代碼, 目的在于插入一個id名為”button”的盒子(div),且其內含有一個鏈接<a href=”#”></a>.


      button a{

      width:160px;

      height:60px;

      display:block;

      background:url(../image/button.png) no-repeat 0 0;

      }



      在css文件中寫入以上代碼, 目的在于控制盒子中鏈接的表現, 通過名為”#button a”的選擇器來實現. 鏈接的寬高為160px*60px, 背景為圖片button.png.



      在這強調一下display:block的作用. 由于在html文件中,鏈接<a href=”#”> </a>中沒有任何的內容(content)填充, 如果沒有聲明”display:block”, 那么即使聲明了選擇器”#button a”的寬高, 瀏覽器也會因為html文件中沒有內容而無法顯示鏈接. 所以”display:block”在這里的作用就在于強制瀏覽器顯示沒有內容填充的鏈接. 


      button a:link { background-position:0 0;}



      用偽類選擇器a:link聲明鏈接的背景圖片在左上角顯示, 即距離左邊和頂邊分別0, 0. 但由于已經在選擇器 “#button a”中聲明了圖片位置, 此代碼可有可無.


      button a:hover { background-position:0 -60px;} 

      button a:active { background-position:0 -120px;}

      button a:visited { background-position:0 -180px;}



      用偽類選擇器a:hover聲明鼠標懸停時, 背景圖片上移60px, 而使排在第二位的綠色小圖片顯示出來;



      用偽類選擇器a:active聲明在鼠標點擊與釋放之間的狀態時, 背景圖片上移120px, 而使排在第三位的紅色小圖片顯示;



      用偽類選擇器a:visited聲明在鏈接被點擊或訪問過時, 背景圖片上移180px, 而使排在第四位的灰色小圖片顯示;



      現在你基本了解了css動態按鈕的制作過程, 但以上css代碼還存在一個嚴重的缺陷, 相信你會很快發現問題所在——這個按鈕居然是一個”一次性按鈕“, 也就是說這個按鈕在點擊第一次后, 就一直顯示那個灰色小圖片, 你能想出解決方法嗎?


    日歷

    鏈接

    個人資料

    藍藍設計的小編 http://www.skdbbs.com

    存檔

    主站蜘蛛池模板: WWW国产精品内射老师| 柠檬福利精品视频导航| 国产精品岛国久久久久| 日本熟妇亚洲欧美精品区| 99国产精品私拍pans大尺度| 亚洲国产精品成人精品无码区| 国产三级精品三级| 午夜精品美女写真福利| 国产成人精品午夜福利| 亚洲AV永久无码精品水牛影视| 四虎成人精品国产永久免费无码| 人精品影院| 麻豆精品久久久一区二区| 国产精品成人A区在线观看| 亚洲精品tv久久久久久久久 | 永久免费精品影视网站| 久久狠狠一本精品综合网| 成人午夜精品久久久久久久小说 | 热综合一本伊人久久精品| 国产精品你懂的在线播放| 久久精品国产一区| 高清在线亚洲精品国产二区| 国内精品久久久久影院优| 日韩精品久久久久久免费| 亚洲AV日韩精品久久久久久| 欲帝精品福利视频导航| 亚洲精品无码AV中文字幕电影网站| 麻豆精品视频在线观看| 久久91这里精品国产2020| 国产精品亚洲不卡一区二区三区| 午夜精品美女自拍福到在线| 91精品国产91久久久久久蜜臀| 欧美精品华人在线| 91嫩草亚洲精品| 国产精品乱视频| 精品人妻系列无码人妻免费视频| 国产午夜精品一区二区| 久久97久久97精品免视看秋霞| 久久精品国产72国产精福利| 精品一区二区三区免费视频| 欧美日韩精品久久久久|