当前位置: 首页 > article >正文

Css:属性选择器、关系选择器及伪元素

css的属性选择器:

注:属性值只能由数字,字母,下划线,中划线组成,并且不能以数字开头。

1、[属性] 选择含有指定属性的元素,用[]中括号表示。

<style>
/*注意大小写区分 注意前后顺序 样式层叠覆盖*/
[title]{color:red;}
p[title]{color:blue;}
</style>

<p title="titleValue">属性选择器p标签含有title属性测试</p>
<p title="Titlevalue">属性选择器p标签含有title属性测试</p>
<p>属性选择器p标签无title属性测试</p>
<br>
<div title="valueTitle">属性选择器div标签含有title属性测试</div>
<div title="Valuetitle">属性选择器div标签含有title属性测试</div>
<div>属性选择器div标签无title属性测试</div>

 

 2、[属性=属性值] 选择属性为某值的元素

<style>
/*注意大小写区分 注意前后顺序 样式层叠覆盖*/
[title]{color:green}
p[title]{color:#fca600}
p[title=Titlevalue]{color:blue;}
[title=valueTitle]{color:red;}
</style>

<p title="titleValue">属性选择器p标签含有title属性测试</p>
<p title="Titlevalue">属性选择器p标签含有title属性测试</p>
<p>属性选择器p标签无title属性测试</p>
<br>
<div title="valueTitle">属性选择器div标签含有title属性测试</div>
<div title="Valuetitle">属性选择器div标签含有title属性测试</div>
<div>属性选择器div标签无title属性测试</div>

 

3、[属性^=属性值] 选择含有指定属性和指定属性值开头的元素

<style>
/*注意大小写区分 注意前后顺序 样式层叠覆盖*/
p[title]{color:green;}
p[title^=title]{color:#fca600;}
[title^=Value]{color:red;}
</style>

<p title="titleValue">属性选择器p标签含有title属性测试</p>
<p title="Titlevalue">属性选择器p标签含有title属性测试</p>
<p>属性选择器p标签无title属性测试</p>
<br>
<div title="valueTitle">属性选择器div标签含有title属性测试</div>
<div title="Valuetitle">属性选择器div标签含有title属性测试</div>
<div>属性选择器div标签无title属性测试</div>

 

  4、[属性$=属性值] 选择含有指定属性和指定属性值结尾的元素

<style>
/*注意大小写区分 注意前后顺序 样式层叠覆盖*/
/*p[title]{color:green;} 优先级更高*/
div[title$=title]{color:#fca600;}
[title$=Value]{color:red;}
</style>

<p title="titleValue">属性选择器p标签含有title属性测试</p>
<p title="Titlevalue">属性选择器p标签含有title属性测试</p>
<p>属性选择器p标签无title属性测试</p>
<br>
<div title="valueTitle">属性选择器div标签含有title属性测试</div>
<div title="Valuetitle">属性选择器div标签含有title属性测试</div>
<div>属性选择器div标签无title属性测试</div>

 

5、[属性*=属性值] 选择属性中含有指定属性值的元素

<style>
/*注意大小写区分 样式层叠覆盖*/
[title]{color:green;}
div[title*=title]{color:#fca600;}
[title*=value]{color:red;}
</style>

<p title="titleValue">属性选择器p标签含有title属性测试</p>
<p title="Titlevalue">属性选择器p标签含有title属性测试</p>
<p>属性选择器p标签无title属性测试</p>
<br>
<div title="valueTitle">属性选择器div标签含有title属性测试</div>
<div title="Valuetitle">属性选择器div标签含有title属性测试</div>
<div>属性选择器div标签无title属性测试</div>

 

关系选择器:

1、父>子 选择某元素后面紧邻子元素(第一位子元素及其兄弟)

<style>
/*注意样式层叠覆盖*/
.father > p {color:red}
.father > .childTwo{color:blue}
</style>

<div class="father">
<p>div样式为father中p标签子元素 第一个</p>
<p class="childTwo">div样式为father中p标签子元素 第二个</p>
<p>div样式为father中p标签子元素 第三个</p>
</div>
<br>
<div>
<p>div无样式p标签子元素 第一个</p>
<p class="childTwo">div无样式p标签子元素 第二个</p>
<p>div无样式p标签子元素 第三个</p>
</div>

 

   2、父 子 选择某元素后面的所有子元素

<style>
/*注意样式层叠覆盖*/
.father p {color:red}
.father .childTwo{color:blue}
.childTwo{color:green}
</style>

<div class="father">
<p>div样式为father中p标签子元素 第一个</p>
<p class="childTwo">div样式为father中p标签子元素 第二个</p>
<p>div样式为father中p标签子元素 第三个</p>
</div>
<br>
<div>
<p>div无样式p标签子元素 第一个</p>
<p class="childTwo">div无样式p标签子元素 第二个</p>
<p>div无样式p标签子元素 第三个</p>
</div>

 

  3、兄+弟 选择紧接在某元素的兄弟元素,二者需有相同父元素

<style>
/*注意样式层叠覆盖*/
.father p + .childTwo{color:red}
.childOne + .childTwo{color:blue}
</style>

<div class="father">
<p>div样式为father中p标签子元素 第一个</p>
<p class="childTwo">div样式为father中p标签子元素 第二个</p>
<p>div样式为father中p标签子元素 第三个</p>
</div>
<br>
<div>
<p class="childOne">div无样式p标签子元素 第一个</p>
<p class="childTwo">div无样式p标签子元素 第二个</p>
<p>div无样式p标签子元素 第三个</p>
</div>

 

 4、兄~弟 选取某个元素之后的所有相同元素 

<style>
/*注意样式层叠覆盖*/
.childTwo ~ p{color:red}
.father ~ div{color:blue}
div ~ .childOne{color:green}
</style>

<div class="father">
<p>div样式为father中p标签子元素 第一个</p>
<p class="childTwo">div样式为father中p标签子元素 第二个</p>
<p>div样式为father中p标签子元素 第三个</p>
</div>
<br>
<div>
<p class="childTwo">div无样式p标签子元素 第一个</p>
<p>div无样式p标签子元素 第二个</p>
<p>div无样式p标签子元素 第三个</p>
</div>
<br>
<div class="childOne">
<div>div无样 第一个</div>
<p>div无样式p标签子元素 第一个</p>
<p>div无样式p标签子元素 第二个</p>
</div>

 

伪元素:

不在DOM中的元素,但可为其添加样式 

1、::before(:before)和::after(:after),注:content是必须的

<style>
div{display:flex;align-items:center;}
div:before{content:'嗨,';color:red}
div:after{content:"";width:10px;height:10px;background:blue;margin-left:5px;}
</style>

<div>米拉</div>

 

2、::first-line(:first-line)和::first-letter(:first-letter) 

::first-line(:first-line)用于块级元素,设置附属元素第一个行内容的样式

::first-letter(:first-letter) 用于块级元素,设置附属元素第一个字母(字)的样式 

<style>
div:first-line{color:green;}
div:first-letter{color:red;font-size:24px;}
</style>
<div>
<p>测试first-line和first-letter的第一个行文字</p>
<p>测试first-line和first-letter的第二个行文字</p>
<p>测试first-line和first-letter的第三个行文字</p>
</div>

 

3、::selection(注:是:: )设置元素中被用户长按鼠标拖动选中部分的样式,只可以应用于少数的CSS样式:color、background、cursor和outline

<style>
p::selection{color:red;background:yellow;}
p::-moz-selection{color:red;background:yellow;}
</style>
<div>
<p>测试first-line和first-letter的第一个行文字</p>
<p>测试first-line和first-letter的第二个行文字</p>
<p>测试first-line和first-letter的第三个行文字</p>
</div>


http://www.kler.cn/news/293612.html

相关文章:

  • 【项目二】C++高性能服务器开发——日志系统(日志器,日志级别,日志事件)
  • 2024高教杯数学建模B题思路
  • shell编程--正则表达式
  • SAP ABAP 程序迁移工具 SAPLINK ABAP GIT
  • Oracle 19c数据库:Windows详细安装与配置指南
  • 【操作系统】进程同步之共享内存
  • [dp]答疑
  • 0.ffmpeg面向对象oopc
  • 进程间通信与管道
  • 如何在Excel中创建一个VBA宏,并设置一个按钮来执行这个宏
  • AWS账号关闭后的影响:您需要知道的一切
  • AWTK HTML View 控件更新
  • 机器学习如何用于音频分析?
  • Unity中使用四元数限制旋转
  • 在目标检测模型中使用正样本和负样本组成的损失函数。
  • 区块链技术介绍
  • 消息可靠投递
  • 数据赋能(199)——开发:数据开发管理——概述、关注焦点
  • 批量文件编码转换用python实现的utf8转gb2312,vscode设置特殊文件的默认打开编码
  • 数据赋能(198)——开发:数据应用——技术方法、主要工具
  • DAY69
  • vue , 微信小程序 , uni-app绑定变量属性
  • 【2024】MySQL库表基本操作
  • 算法:图片压缩算法【Z字行扫描】(Java实现)
  • 相亲交友系统商业开发
  • 【最新华为OD机试E卷-支持在线评测】分糖果(100分)-多语言题解-(Python/C/JavaScript/Java/Cpp)
  • 用ACF和PACF计算出一堆数据的周期个数以及周期时长,数据分析python
  • Linux系统练习笔记【完整版】
  • .NET/C#⾯试题汇总系列:⾯向对象
  • SpringBoot整合openApi