前端学习<二>CSS基础——10-CSS3选择器详解

CSS3介绍

CSS3在CSS2基础上,增强新增了许多特性, 弥补了CSS2的众多不足之处,使得Web开发变得更为高效和便捷。

CSS3的现状

  • 浏览器支持程度不够好,有些需要添加私有前缀

  • 移动端支持优于PC端

  • 不断改进中

  • 应用相对广泛

### 应对的策略:渐进增强

  • (1)坚持渐进增强的原则:让低版本浏览器能正常访问页面,高版本的浏览器用户体验更好。【重要】

比如说,同样是一个头像,可能在低版本的浏览器中,头像方的;在高版本的浏览器中,头像是圆的。

  • (2)考虑用户群体。

  • (3)遵照产品的方案。

参考链接:

  • 渐进增强 VS 优雅降级 | 简书

  • 渐进增强和优雅降级之间的不同(面试题目)

浏览器的版本问题

由于CSS3普遍存在兼容性问题,为了避免因兼容性带来的干扰,浏览器的建议版本为:

  • Chrome浏览器 version 46+

  • Firefox浏览器 firefox 42+

如何使用手册

CSS参考手册的网址:http://css.doyoe.com/

CSS参考手册的下载链接:http://download.csdn.net/download/smyhvae/10243974

在查看CSS参考手册时,需要注意以下符号:

比如说,{1,4}表示可以设置一至四个参数。

下面讲CSS3的基础知识。本文讲一下 CSS3 选择器的内容。

CSS3 选择器

我们之前学过 CSS 的选择器,比如:

      div 标签选择器
 ​
      .box 类名选择器
 ​
      #box id选择器
 ​
      div p 后代选择器
 ​
      div.box 交集选择器
 ​
      div,p,span 并集选择器
 ​
      div>p 子代选择器
 ​
      * : 通配符
 ​
      div+p: 选中div后面相邻的第一个p
 ​
      div~p: 选中的div后面所有的p
 ​

CSS3新增了许多灵活查找元素的方法,极大的提高了查找元素的效率和精准度。CSS3选择器与 jQuery 中所提供的绝大部分选择器兼容。

属性选择器

属性选择器的标志性符号是 []

匹配含义:

 ^:开头  $:结尾  *:包含

格式:

  • E[title] 选中页面的E元素,并且E存在 title 属性即可。

  • E[title="abc"]选中页面的E元素,并且E需要带有title属性,且属性值完全等于abc。

  • E[attr~=val] 选择具有 att 属性且属性值为:用空格分隔的字词列表,其中一个等于 val 的E元素。

  • E[attr|=val] 表示要么是一个单独的属性值,要么这个属性值是以“-”分隔的。

  • E[title^="abc"] 选中页面的E元素,并且E需要带有 title 属性,属性值以 abc 开头。

  • E[title$="abc"] 选中页面的E元素,并且E需要带有 title 属性,属性值以 abc 结尾。

  • E[title*="abc"] 选中页面的E元素,并且E需要带有 title 属性,属性值任意位置包含abc。

比如说,我们用属性选择器去匹配标签的className,是非常方便的。

这里我们用class属性来举例。代码举例:

 <!DOCTYPE html>
 <html lang="en">
 <head>
     <meta charset="UTF-8">
     <title>选择器 - 属性</title>
     <style>
         body {
             margin: 0;
             padding: 0;
             font-family: '微软雅黑';
             background-color: #F7F7F7;
         }
 ​
         .wrapper {
             width: 1024px;
             margin: 0 auto;
         }
 ​
         .wrapper > section {
             min-height: 300px;
             margin-bottom: 30px;
             box-shadow: 1px 1px 4px #DDD;
             background-color: #FFF;
         }
 ​
         .wrapper > header {
             text-align: center;
             line-height: 1;
             padding: 20px;
             margin-bottom: 10px;
             font-size: 30px;
         }
 ​
         .wrapper section > header {
             line-height: 1;
             padding: 10px;
             font-size: 22px;
             color: #333;
             background-color: #EEE;
         }
 ​
         .wrapper .wrap-box {
             padding: 20px;
         }
 ​
         form {
             width: 300px;
             height: 300px;
             margin: 0 auto;
         }
 ​
         form input[type="text"] {
             width: 200px;
             height: 30px;
         }
 ​
         form input[type="password"] {
             width: 200px;
             height: 30px;
         }
 ​
         .attr1 {
 ​
         }
 ​
         .download {
         }
 ​
         .attr1 a[href="./a.rmvb"] {
             color: red;
         }
 ​
         .attr1 a[href="./b.rmvb"] {
             color: pink;
         }
 ​
         /*  E[attr~=val] 表示的一个单独的属性值 这个属性值是以空格分隔的*/
         .attr2 a[class~="download"] {
             color: red;
         }
 ​
         /*  E[attr|=val] 表示的要么一个单独的属性值 要么这个属性值是以"-"分隔的*/
         .attr3 a[class|="download"] {
             color: red;
         }
 ​
         /*  E[attr*=val] 表示的属性值里包含val字符并且在“任意”位置 */
         .attr4 a[class*="download"] {
             color: red;
         }
 ​
         /*  E[attr^=val] 表示的属性值里包含val字符并且在“开始”位置 */
         .attr5 a[class^="download"] {
             color: red;
         }
 ​
         /*  E[attr$=val] 表示的属性值里包含val字符并且在“结束”位置 */
         .attr6 a[class$="download"] {
             color: red;
         }
     </style>
 </head>
 <body>
 <div class="wrapper">
     <header>CSS3-属性选择器</header>
     <section>
         <header>简介</header>
         <div class="wrap-box">
             <form action="">
 ​
                 <ul>
                     <li>
                         姓名: <input type="text">
                     </li>
                     <li>
                         密码: <input type="password">
                     </li>
 ​
                     <li>
                         性别: <input type="radio">男
                         <input type="radio"> 女
                     </li>
                     <li>
                         兴趣: <input type="checkbox" name="" id="">写代码
                     </li>
                     <li>
                         <input type="submit" value="提交">
                     </li>
                 </ul>
             </form>
         </div>
     </section>
     <section class="attr1">
         <header>E[attr]</header>
         <div class="wrap-box">
             <a href="./a.rmvb" class="download download-movie">下载</a>
             <a href="./b.rmvb" class="download download-movie">下载</a>
             <a href="./a.mp3" class="download download-music">下载</a>
         </div>
     </section>
     <section class="attr2">
         <header>E[attr~=attr]</header>
         <div class="wrap-box">
             <a href="./a.rmvb" class="download download-movie">下载</a>
             <a href="./b.rmvb" class="download download-movie">下载</a>
             <a href="./a.mp3" class="download download-music">下载</a>
         </div>
     </section>
     <section class="attr3">
         <header>E[attr|=attr]</header>
         <div class="wrap-box">
             <a href="./a.rmvb" class="download">下载</a>
             <a href="./b.rmvb" class="download-movie">下载</a>
             <a href="./a.mp3" class="download-music">下载</a>
         </div>
     </section>
     <section class="attr4">
         <header>E[attr*=val]</header>
         <div class="wrap-box">
             <a href="./a.rmvb" class="download">下载</a>
             <a href="./b.rmvb" class="moviedownload">下载</a>
             <a href="./a.mp3" class="downloadmusic">下载</a>
         </div>
     </section>
     <section class="attr5">
         <header>E[attr^=val]</header>
         <div class="wrap-box">
             <a href="./a.rmvb" class="download">下载</a>
             <a href="./b.rmvb" class="moviedownload">下载</a>
             <a href="./a.mp3" class="downloadmusic">下载</a>
         </div>
     </section>
     <section class="attr6">
         <header>E[attr$=val]</header>
         <div class="wrap-box">
             <a href="./a.rmvb" class="download">下载</a>
             <a href="./b.rmvb" class="moviedownload">下载</a>
             <a href="./a.mp3" class="downloadmusic">下载</a>
         </div>
     </section>
 </div>
 </body>
 </html>

最后来张表格:

结构伪类选择器

伪类选择器的标志性符号是 :

CSS中有一些伪类选择器,比如:link:visited:hover:active:focus

CSS3又新增了其它的伪类选择器。这一小段,我们来学习CSS3中的结构伪类选择器:即通过结构来进行筛选。

1、格式:(第一部分)(重要)

  • E:first-child 匹配父元素的第一个子元素E。

  • E:last-child 匹配父元素的最后一个子元素E。

  • E:nth-child(n) 匹配父元素的第n个子元素E。注意,盒子的编号是从1开始算起,不是从0开始算起。

  • E:nth-child(odd) 匹配奇数

  • E:nth-child(even) 匹配偶数

  • E:nth-last-child(n) 匹配父元素的倒数第n个子元素E。

理解:

(1)这里我们要好好理解父元素的含义,它指的是:以 E 元素的父元素为参考。

(2)注意:以上选择器中所选到的元素的类型,必须是指定的类型E,如果选不中,则无效。这个要好好理解,具体可以看CSS参考手册中的E:nth-child(n)的示例。我们可以理解成:先根据选择器找到选中的全部位置,如果发现某个位置不是类型E,则该位置失效

(3)另外,E:nth-child(n)这个属性也很有意思。比如,针对下面这样一组标签:

     <ul>
         <li>1</li>
         <li>2</li>
         <li>3</li>
         <li>4</li>
         <li>5</li>
         <li>6</li>
         <li>7</li>
         <li>8</li>
         <li>9</li>
         <li>10</li>
     </ul>

上方代码中:

  • 如果选择器写成li:nth-child(2),则表示第2个 li

  • 如果选择器写成li:nth-child(n),则表示所有的li。因为此时的 n 表示 0,1,2,3,4,5,6,7,8.....(当n小于1时无效,因为n = 0 也是不会选中的)

  • 如果选择器写成li:nth-child(2n),则表示所有的第偶数个 li。

  • 如果选择器写成li:nth-child(2n+1),则表示所有的第奇数个 li。

  • 如果选择器写成li:nth-child(-n+5),则表示前5个 li。

  • 如果选择器写成li:nth-last-child(-n+5),则表示最后5个 li。

  • 如果选择器写成li:nth-child(7n),则表示选中7的倍数。。

上面列举的选择器中,我们只要记住: n 表示 0,1,2,3,4,5,6,7,8.....就很容易明白了。

2、格式:(第二部分)

  • E:first-of-type 匹配同类型中的第一个同级兄弟元素E。

  • E:last-of-type 匹配同类型中的最后一个同级兄弟元素E。

  • E:nth-of-type(n) 匹配同类型中的第n个同级兄弟元素E。

  • E:nth-last-of-type(n) 匹配同类型中的倒数第n个同级兄弟元素E。

既然上面这几个选择器带有type,我们可以这样理解:先在同级里找到所有的E类型,然后根据 n 进行匹配。

3、格式:(第三部分)

  • E:empty 匹配没有任何子节点(包括空格等text节点)的元素E。

  • E:target 匹配相关URL指向的E元素。要配合锚点使用。

举例:

我们可以把多个伪类选择器结合起来使用,比如:

如果想把上图中,第一行的前三个 span 标红,我们可以这样使用结构伪类选择器:

     dt:first-child span:nth-of-type(-n+3) {
         color: red;
     }

最后来张表格:

伪元素选择器

伪元素选择器的标志性符号是 ::

1、格式:(第一部分)

  • E::before 设置在 元素E 前面(依据对象树的逻辑结构)的内容,配合content属性一起使用。

  • E::after 设置在 元素E 后面(依据对象树的逻辑结构)的内容,配合content属性一起使用。

E:afterE:before在旧版本里是伪类,在 CSS3 这个新版本里是伪元素。新版本里,E:afterE:before会被自动识别为E::afterE::before,按伪元素来对待,这样做的目的是用来做兼容处理。

举例:

 <!DOCTYPE html>
 <html>
 <head lang="en">
     <meta charset="UTF-8">
     <title></title>
     <style>
 ​
         /*::before 和::after 是通过 css 模拟出的html标签的效果*/
         span::before{
             content:"smyhvae";
             color:red;
             background-color: pink;
             width: 50px;
             height: 50px;
             display: inline-block;
         }
 ​
         span::after{
             content:"永不止步";
             color:yellowgreen;
         }
 ​
         /*给原本的span标签设置一个默认的属性*/
         span{
             border: 1px solid #000;
         }
     </style>
 </head>
 <body>
 ​
 <span>生命壹号</span>
 </body>
 </html>
 ​

效果如下:

上图可以看出

  • 通过伪元素选择器,就可以添加出类似于span标签的效果(记得要结合 content 属性使用)。

  • 通过这两个属性添加的伪元素,是行内元素,需要转换成块元素才能设置宽高。

2、格式:(第二部分)

  • E::first-letter 设置元素 E 里面的第一个字符的样式。

  • E::first-line 设置元素 E 里面的第一行的样式。

  • E::selection 设置元素 E 里面被鼠标选中的区域的样式(一般设置颜色和背景色)。

E::first-letter 的举例:

E::first-line的举例:

最后来张表格:

写在最后:希望大家可以点个关注点个赞,这对up真的很重要!谢谢!

本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/503165.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

网络性能提升10%,ZStack Edge 云原生超融合基于第四代英特尔®至强®可扩展处理器解决方案发布

随着业务模式的逐渐转变、业务架构逐渐变得复杂&#xff0c;同时容器技术的兴起和逐渐成熟&#xff0c;使得Kubernetes、微服务等新潮技术逐步应用于业务应用系统上。 为了充分释放性能、为业务系统提供更高效的运行环境&#xff0c;ZStack Edge 云原生超融合采用了第四代英特尔…

第十四届蓝桥杯javaA组 阶乘的和

这个题我做的时候已经看出来&#xff0c;最小的m一定是最小的Ai&#xff0c;然后如果想让想让m1那么只能让最小的Ai的数量是m1的倍数因为比如说mAmin 1 那么想让m&#xff01;是 Ai阶乘和的倍数只有 nAmin&#xff01;%m&#xff01;0 然后我就不知道如何就m等于Amin2的情况了…

Spring 自定义注解 为 BeanDefinition 添加 qualifier 信息 从而约束自动装配范围

为什么写这篇文章 Spring 支持类型注入&#xff0c;并且可以通过Qualifier 或者Mate 调整类型注入的范围。但是通过自定义注解结合现有的 Qualifier 使用起来有种种困难。 将 Qualifier 融合在自定义注解中&#xff0c;在使用 AliasFor 遇到问题仅仅检查注解中的一部分内容是否…

2024年北京通信展|北京国际信息通信展览会|北京PT展

2024年北京通信展|北京国际信息通信展览会|北京PT展 2024年中国国际信息通信展览会&#xff08;PTEXPO&#xff09;&#xff0c;是由工业和信息化部主办的ICT行业盛会&#xff0c;自1990年创办以来&#xff0c;已成功举办31届&#xff0c;是反映信息通信行业发展最新成果的重要…

最小质因数 == 最大质因数,不等式秒了!

起因&#xff1a; 在洛谷做题遇到了这道题~ 一看咿呀&#xff0c;又是道数学题~ 首先我们要了解一下&#xff0c;什么是质数&#xff1f; 我记得好像有年高考题的前几题好像考了这玩意来着&#xff0c;质数的概念好像在小学学过&#xff0c;上了初中后基本都没有用过了~ 质数就…

error lsof 0.1 does not meet the minimal requirement

很多小伙伴在linux虚拟机中采用Centos 7镜像安装TitanIDE时&#xff0c;会报错如下信息 error lsof 0.1 does not meet the minimal requirement 这是因为lsof依赖版本较低&#xff0c;只需要在命令行输入 sudo yum install lsof 按下回车以后&#xff0c;命令行会弹出提示命令…

C语言例1-7:以下程序段中执行循环的次数是

代码如下&#xff1a; x-2; do { xx*x; } while(!x); 执行循环次数是&#xff1a;1 先执行后判断 代码如下&#xff1a; #include<stdio.h> int main(void) {int x;x-2;do{ xx*x; printf("\n");printf("x %d\n",x);}while(!x);return 0; } 结果…

Linux - 第三节

改变用户类型 su 仅单纯的进行身份变化 依旧处于普通用户里面 su - 进行重新登录更改身份 退出用exit / ctrld su 用户名 改成成其他身份 对一条命令进行提权 sudo command r:可读 w:可写 x:可执行 -:对应的权限位置&#xff0c;没有权限 去掉所有权限 chmod u…

2024 ccfcsp认证打卡【汇总】

202312-1 仓库规划 202312-2 因子化简 202312-3 树上搜索 202309-1 坐标变换&#xff08;其一&#xff09; 202309-2 坐标变换&#xff08;其二&#xff09; 202305-1 重复局面 202305-2 矩阵运算 202303-1 田地丈量 202303-2 垦田计划 202212-1 现值计算 202212-2 训练计划 20…

Redis实战篇-利用逻辑过期解决缓存击穿问题

实战篇Redis 3.0 、利用逻辑过期解决缓存击穿问题 需求&#xff1a;修改根据id查询商铺的业务&#xff0c;基于逻辑过期方式来解决缓存击穿问题 思路分析&#xff1a;当用户开始查询redis时&#xff0c;判断是否命中&#xff0c;如果没有命中则直接返回空数据&#xff0c;不…

打工人神器! Raccoon 代码小浣熊

继这三个之后&#xff0c;今天又来了一个 [ Raccoon代码小浣熊 ] 核心精要与产品特点 全面支持多种编程语言和IDE&#xff1a;「代码小浣熊」支持超过90种主流编程语言&#xff0c;包括但不限于Python、Java、JavaScript、C、Go和SQL等。同时&#xff0c;它集成了市面上主流的…

基于jsp+mysql+Spring+hibernate+的SSH在线学习交流论坛平台

基于jspmysqlSpringhibernate的SSH在线学习交流论坛平台 博主介绍&#xff1a;多年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 央顺技术团队 Java毕设项目精品实战案例《1000套》 欢迎点赞 收藏 ⭐留言 文末…

Unreal的Quixel Bridge下载速度过慢、下载失败

从Quixel Bridge下载MetaHuman模型&#xff0c;速度非常慢&#xff0c;而且经常下载失败&#xff0c;从头下载。 可以从Quixel Bridge的右上角我的图标->Support->Show Logs打开日志目录 downloaded-assets目录下为下载的资源 bridge-plugin.log文件记录了下载URL和下载…

java(1)之环境部署

1、下载安装包 直接百度java 点击这个就可以&#xff0c;进去之后下载&#xff0c;根据自身情况&#xff0c;window就下Windows版本的记得下那个jdk别下别的&#xff08;用不了&#xff09;&#xff0c;然后下一个编译器可以是idea可以是eclipse都可以 2、环境搭建 分为两步…

如何确保实物档案的安全

确保实物档案的安全有以下几个关键点&#xff1a; 1. 建立完善的安全措施&#xff1a;为实物档案建立专门的存储区域&#xff0c;控制进出口&#xff0c;限制访问权限&#xff0c;并使用安全锁和监控设备等物理安保措施。 2. 规范档案管理制度&#xff1a;建立档案管理制度&…

算法学习——LeetCode力扣动态规划篇10

算法学习——LeetCode力扣动态规划篇10 583. 两个字符串的删除操作 583. 两个字符串的删除操作 - 力扣&#xff08;LeetCode&#xff09; 描述 给定两个单词 word1 和 word2 &#xff0c;返回使得 word1 和 word2 相同所需的最小步数。 每步 可以删除任意一个字符串中的一个…

使用 golang 以及 Gin 框架,将上传的图片在不保存至本地的情况下添加水印,并上传至阿里云 OSS

正如标题所述&#xff0c;使用golang对上传图片添加水印&#xff0c;以及将图片上传到阿里云OSS&#xff0c;网上一搜索&#xff0c;便有你想要的结果了&#xff0c;可是&#xff0c;他们却先将上传图片添加水印后保存在本地&#xff0c;而后再将添加了水印的图片上传到阿里云O…

【个人笔记】python界面美化

目录 标题栏美化 样例展示 代码 配套鼠标移动 完整展示 标题栏美化 样例展示 代码 import tkinter as tk from tkinter import ttk from PIL import Image, ImageTk import subprocess import sysdef open_buy_quantity():window.destroy()subprocess.run(["p…

网际协议 - IP

文章目录 目录 文章目录 前言 1 . 网际协议IP 1.1 网络层和数据链路层的关系 2. IP基础知识 2.1 什么是IP地址? 2.2 路由控制 3. IP地址基础知识 3.1 IP地址定义 3.2 IP地址组成 3.3 IP地址分类 3.4 子网掩码 IP地址分类导致浪费? 子网与子网掩码 3.5 CIDR与…

记录个人学习golang路线(如何学习golang,如何转golang)

最近好久没更&#xff0c;在看兔兔的博客&#xff0c;学习golang&#xff0c;兔兔的文章&#xff0c;有一定的编程经验 && 初学golang者&#xff0c;一定要看&#xff0c;如果是其他语言转golang&#xff0c;那就必须要看了&#xff0c;可以帮助你了解golang的语法&…