日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > CSS >内容正文

CSS

css伪类元素加在元素前,CSS伪类:before在元素之前 :after 在元素之后实例讲解

發布時間:2023/12/4 CSS 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 css伪类元素加在元素前,CSS伪类:before在元素之前 :after 在元素之后实例讲解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本教程簡單的介紹一下關于CSS偽類:before, :after詳解,有需要了解的朋友可以參考一下下。

:before 偽元素在元素之前添加內容

這個偽元素允許創作人員在元素內容的最前面插入生成內容。默認地,這個偽元素是行內元素,不過可以使用屬性 display 改變這一點。

:after 偽元素在元素之后添加內容

這個偽元素允許創作人員在元素內容的最后面插入生成內容。默認地,這個偽元素是行內元素,不過可以使用屬性 display 改變這一點。

復制代碼代碼如下:

偽類導個航..

/*css部分, 留意其中border, margin, left, right的取值*/

body{background:#EEE;margin:0px;padding:0px;font-size:14px;font-family:Microsoft Yahei;color:#FFF;}

#nav_demo{overflow:hidden;width:520px;margin:100px auto 0px;}

#nav_demo span{float:left;position:relative;padding:0px 10px;height:30px;line-height:30px;margin-left:20px;cursor:pointer;}

.shenzhen{background:#4FA3DA;}

.guangzhou{background:#666912;}

.shanghai{background:#9B44BC;}

.beijing{background:#9B2222;}

.chengdu{background:#804B12;}

.shenzhen:hover{background:#387399;}

.guangzhou:hover{background:#4B4D0E;}

.shanghai:hover{background:#692A81;}

.beijing:hover{background:#711A1A;}

.chengdu:hover{background:#59390E;}

.shenzhen:before,.shenzhen:after,.guangzhou:before,.guangzhou:after{

border-style:solid;

border-width:15px 10px;

content:"";

height:0;

position:absolute;

top:0;

width:0;

}

.shenzhen:before{border-color:#4FA3DA #4FA3DA transparent transparent;left:-20px;}

.guangzhou:before{border-color:#666912 #666912 transparent transparent;left:-20px;}

.shenzhen:after{border-color:transparent transparent #4FA3DA #4FA3DA;right:-20px;}

.guangzhou:after{border-color:transparent transparent #666912 #666912;right:-20px;}

.shenzhen:hover:before{border-color:#387399 #387399 transparent transparent;left:-20px;}

.guangzhou:hover:before{border-color:#4B4D0E #4B4D0E transparent transparent;left:-20px;}

.shenzhen:hover:after{border-color:transparent transparent #387399 #387399;right:-20px;}

.guangzhou:hover:after{border-color:transparent transparent #4B4D0E #4B4D0E;right:-20px;}

#tips{float:right;margin-right:200px;margin-top:20px;color:#8BA612;width:280px;background:#333;border:solid 1px #000;padding:5px 10px;}

#header{position:absolute;top:0px;width:100%;height:30px;line-height:30px;background:#333;border-bottom:solid 1px #000;}

#header span{padding-left:30px;padding-right:10px;}

#header a{text-decoration:none;color:#8BA612;}

#header a:hover{text-decoration:underline;}

#footer{position:absolute;bottom:0px;width:100%;text-align:center;height:30px;line-height:30px;background:#333;border-top:solid 1px #000;}

#footer a{color:#8BA612;text-decoration:none;padding-left:5px;}

#footer a:hover{text-decoration:underline;}

返回《回來鋤草..CSS偽類:before, :after》

8.29 深圳

9.10 廣州

10.15 上海

11.12 北京

12.10 成都

Tips: 你用IE6 IE7, 那就活該你看不到效果...

上面積實例,下面我們來一下介紹一下

復制代碼代碼如下:

8.29 深圳

9.10 廣州

10.15 上海

11.12 北京

12.10 成都

css部份

復制代碼代碼如下:

/*css部分, 留意其中border, margin, left, right的取值*/

#nav_demo{margin-top:20px;margin-left:20px;font-size:12px;font-family:Microsoft Yahei;overflow:hidden;}

#nav_demo span{float:left;color:#FFF;position:relative;padding:0px 10px;height:30px;line-height:30px;margin-left:20px;cursor:pointer;}

.shenzhen{background:#4FA3DA;}

.guangzhou{background:#666912;}

.shanghai{background:#9B44BC;}

.beijing{background:#9B2222;}

.chengdu{background:#804B12;}

.shenzhen:hover{background:#387399;}

.guangzhou:hover{background:#4B4D0E;}

.shanghai:hover{background:#692A81;}

.beijing:hover{background:#711A1A;}

.chengdu:hover{background:#59390E;}

.shenzhen:before,.shenzhen:after,.guangzhou:before,.guangzhou:after{

border-style:solid;

border-width:15px 10px;

content:"";

height:0;

position:absolute;

top:0;

width:0;

}

.shenzhen:before{border-color:#4FA3DA #4FA3DA transparent transparent;left:-20px;}

.guangzhou:before{border-color:#666912 #666912 transparent transparent;left:-20px;}

.shenzhen:after{border-color:transparent transparent #4FA3DA #4FA3DA;right:-20px;}

.guangzhou:after{border-color:transparent transparent #666912 #666912;right:-20px;}

/* 偽類可以像下邊這樣疊加使用...*/

.shenzhen:hover:before{border-color:#387399 #387399 transparent transparent;left:-20px;}

.guangzhou:hover:before{border-color:#4B4D0E #4B4D0E transparent transparent;left:-20px;}

.shenzhen:hover:after{border-color:transparent transparent #387399 #387399;right:-20px;}

.guangzhou:hover:after{border-color:transparent transparent #4B4D0E #4B4D0E;right:-20px;}

【第1個條件出現了 – :before, :after偽類可以在不增加html代碼量得情況下, 為元素增加效果】

說到了其中的偽類before,after. 正如其單詞含義, 就是在作用的元素前, 或者后實現某些效果. 但是在兼容性上會有一些問題, IE8, IE8+, Chrome, Safari, Firefox.

【第2個條件 – border在寬高為0的元素上, 四個方向都是三角形】

很早之前看到過用純css來實現一個折角的效果. 其實也是用的css中border的特性.

各位可以自己測試下, 給一個寬高都為0的元素加一個很寬的border, 同時, 給border的四個方向分別設置不同的顏色值. 之后會發現, border的上下左右都是三角形(這里是在寬高為0的情況下, 測試用.并不是說邊框就是三角形..??~~). 也就是說, border四個方向的邊框之間斜面緊密連接的.

【第3個條件 – border-color四個參數可以設置相鄰兩邊透明, 另外兩邊同色, 即可出現三角形】

之后, border-color的屬性值中有一個transparent(透明), 就像margin的定義一樣, border-color有四個參數, 分別代表上, 右, 下, 左的顏色值. 這樣只要將相鄰兩邊的顏色設置為透明, 另外兩邊的顏色設置為相同顏色, 就會出現一個三角形.

在之后, 三角形的大小如何控制. 務必留意寬高為0的元素, 其大寬度邊框的樣子. 上下邊框的和是元素實際的高度, 左右邊框的和是元素的實際寬度, 所以, 不要慣性思維, 把一個邊的寬高當做是實際的寬高. 這樣計算的結果就會讓人比較不解了..

下邊這個很難看的demo是一個寬高為0的元素border

上邊框: 80px #387399

右邊框: 60px #4B4D0E

下邊框: 40px #692A81

左邊框: 20px #711A1A

【第4個條件 – 合理控制高度, 寬度】

css代碼最上邊有句注釋, 說是要留意那幾個值(border, margin, left, right). 原因在于, 需要讓三角形跟內容部分高度一致, 同時還不會被旁邊的元素蓋住. 這就要計算一下了.

了解上邊對border高度寬度的解釋, 然后內容部分建議指定高度, 而不是用padding來撐開, 原因在于, 文字部分的高度因字體的不一致而有所不同, 很難精確控制高度. 當然, 如果閣下對字體研究的透徹程度已經達到慘絕人寰的程度, 那也可以試試..

before和after偽類的使用會占據一定的空間, 所以, 需要計算border的實際寬度, 然后將元素之間的間距, 適當增大, 至少增大到border的寬度(避免被后邊的元素蓋住三角形區域, 當然, 還有其他辦法避免這種問題. 這里只是一提).

總結

以上是生活随笔為你收集整理的css伪类元素加在元素前,CSS伪类:before在元素之前 :after 在元素之后实例讲解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。