data:image/s3,"s3://crabby-images/6fc3c/6fc3c0e1c6a44b91ffcb4f57d1288efcf488f115" alt="HTML5+CSS3+JavaScript 从入门到项目实践(超值版)"
4.4 动态伪类选择器
伪类选择器并不是针对真正的元素使用的选择器,只针对CSS中的伪元素起作用。
4.4.1 内容相关的属性
data:image/s3,"s3://crabby-images/9f4e0/9f4e0ced4d98601a83aebf547d4927b971933d4b" alt=""
内容相关的属性与CSS其他属性一样,同样需要定义在CSS样式的大括号内。content属性是CSS支持的内容相关属性中最重要的一个,该属性的值可以是字符串、url、attr、open-quote等格式,该属性用于向指定元素之前或之后插入指定内容。
【例4-7】(实例文件:ch04\Chap4.7.html)内容相关的属性。
data:image/s3,"s3://crabby-images/53d7d/53d7db771e625f26c178f7f187a33369f86a6f11" alt=""
在上面的代码中,为每一个li之前添加字符串,并设置了字体颜色为红色。
相关的代码实例请参考Chap4.7.html文件,在IE浏览器中运行的结果如图4-10所示。
data:image/s3,"s3://crabby-images/21234/212344deef5a1915eb3140d622e3db1655657e6c" alt=""
图4-10 内容相关的属性
4.4.2 插入图像
data:image/s3,"s3://crabby-images/62f74/62f743e671f9c058d6c1269d52921c73959386e7" alt=""
content属性值除了可以添加字符串外,还可以添加图片,代码如下。
content: url("src")
src指定图片的路径。
【例4-8】(实例文件:ch04\Chap4.8.html)插入图片。
data:image/s3,"s3://crabby-images/bb63d/bb63d4ef76ac7e4c2c13056e06f4cd32bac4d4ef" alt=""
相关的代码实例请参考Chap4.8.html文件,在IE浏览器中运行的结果如图4-11所示。
data:image/s3,"s3://crabby-images/37ba0/37ba0c916f1d70b4f0c38a4dcc2ede068d4b4281" alt=""
图4-11 插入图像
4.4.3 只插入部分元素
data:image/s3,"s3://crabby-images/aa3a3/aa3a31ff66b1dafae01ade065bf5df217c43936c" alt=""
有时候只想为一部分元素添加内容,这时需先把要添加内容的元素找到,如只想给前两个元素添加内容,只需找到前两个元素的选择器,再在其后面添加伪类选择器,这样就可以设置其内容了。
【例4-9】(实例文件:ch04\Chap4.9.html)只插入部分元素。
data:image/s3,"s3://crabby-images/230c4/230c444d99568b294702d37541fb990f534ba1ae" alt=""
相关的代码实例请参考Chap4.10.html文件,IE浏览器中运行的结果如图4-12所示。
data:image/s3,"s3://crabby-images/39f43/39f4363dfc3b0f409cdaf9406a45e245efe27010" alt=""
图4-12 只插入部分元素
4.4.4 配合quotes属性执行插入
data:image/s3,"s3://crabby-images/44ca1/44ca1ddb813729b4a0d16db6938410aa8486e402" alt=""
quotes属性可以定义open-quote和close-quote,然后就可以在content属性中应用它们了。
【例4-10】(实例文件:ch04\Chap4.10.html)配合quotes属性执行插入。
data:image/s3,"s3://crabby-images/07acc/07accf70d12f0d2f33d6cb0a19effbbfe480838c" alt=""
相关的代码实例请参考Chap4.10.html文件,在IE浏览器中运行的结果如图4-13所示。
data:image/s3,"s3://crabby-images/e3a71/e3a7106617411cc212d8e64e429bc051d6996cbb" alt=""
图4-13 配合quotes属性执行插入
4.4.5 配合counter-increment属性添加编号
data:image/s3,"s3://crabby-images/f0972/f0972deb9aced72edc5ebe6ec5d68b8ec2ae78b4" alt=""
counter-increment属性用于定义计数器,如要给多条内容添加编号,就可以通过该属性来设置。定义计数器很简单,只需给需要添加编号的元素定义一个计数器,然后结合content属性在该元素前面添加这个计数器,就可以实现编号了。
【例4-11】(实例文件:ch04\Chap4.11.html)配合unter-increment属性添加编号。
data:image/s3,"s3://crabby-images/97be0/97be06e786409f135572866efb2d31b51af9b0d6" alt=""
相关的代码实例请参考Chap4.11.html文件,在IE浏览器中运行的结果如图4-14所示。
data:image/s3,"s3://crabby-images/10db7/10db78d2ac8b8e8aac828a84fd85625498fdc6a7" alt=""
图4-14 计数器添加编号效果
4.4.6 使用自定义编号
data:image/s3,"s3://crabby-images/22355/2235590d54a48358cbd6604d91ca21190385509b" alt=""
从上面的案例可以发现,CSS默认的编号样式是数字,但有时我们还需要使用自定义编号来满足不同的需要。我们可以通过counter(name,list-style-type)用法来实现使用自定义编号,name是计数器的名字,list-style-type指定自定义编号的样式,它的一部分取值如表4-1所示。
表4-1 自定义编号部分取值
data:image/s3,"s3://crabby-images/d8204/d8204f23c574c9e3e3f979620ebbfd5965d71e8f" alt=""
【例4-12】(实例文件:ch04\Chap4.12.html)使用自定义编号。
data:image/s3,"s3://crabby-images/f0ca0/f0ca02d068fcc59eaa2cf540bac153f5a6219565" alt=""
相关的代码实例请参考Chap4.12.html文件,在IE浏览器中运行的结果如图4-15所示。
data:image/s3,"s3://crabby-images/1f05d/1f05dca55983dca44437f90ea6f13aee9537d0c0" alt=""
图4-15 使用自定义编号
4.4.7 添加多级编号
data:image/s3,"s3://crabby-images/589ef/589ef2083396d5d31a3b1dd57d47077102f23e2e" alt=""
在上面案例中,只是添加了一级编号,还可以添加多级编号,像书的目录一样,可以有多级的编号。下面就使用计数器来实现一个简单的目录形式的编号。
【例4-13】(实例文件:ch04\Chap4.13.html)添加多级编号。
data:image/s3,"s3://crabby-images/e7e89/e7e896464acd80fec031c5d840d14b78294c2d27" alt=""
相关的代码实例请参考Chap4.13.html文件,在IE浏览器中运行的结果如图4-16所示。
我们会发现第二级编号是连续的,正常情况下每一章的第一节应该从1开始,上面的效果不是我们想要的,但是我们可以通过counter-reset属相来改变,该属性用于重置计数器。我们在h2样式中添加“counter-reset:order2;”即可,这样就会重置order2计数器,显示效果如图4-17所示。
data:image/s3,"s3://crabby-images/bdbd8/bdbd861e0aa7c244fee9810003ee9c1a8507d746" alt=""
图4-16 多级计数器的应用
data:image/s3,"s3://crabby-images/535e9/535e92ff0625874c3080734cdb66921e0b613a2c" alt=""
图4-17 重置order2计数器后的效果