CSS和CSS3选择器

作者: 蓝冰海域 | 来源:发表于2017-03-13 18:04 被阅读25次

最常用的选择器类型是类型选择器和后代选择器.类型选择器用来寻找特定类型的元素,比如段落或者标题元素.有时候也被称为元素选择器或简单选择器.

p{color:black}
h1{font-weight:bold}

后代选择器可用了来寻找特定元素或元素组的后代.另外还有ID选择器和类选择器.ID选择器用#替代,类选择器用.替代.

#id{}
<p><span id="id">Harry Knowles</span></p>
.class{}
<p><span class="class">Harry Knowles</span></p>

通用选择器

可能是所有选择器中最强大却最少使用的.作用就像通配符,它匹配所有的元素.用型号代替.最常用的操作就是去除浏览器的padding和margin

*{
    margin: 0px;
    padding: 0px;
}

子选择器

后代选择器可以选择一个元素的所有后代,而子选择器只选择元素的直接后代,即子元素.

<div id="mu">
    <p>Harry Knowles</p>
    <div>
        <p>Harry Knowles</p>
    </div>
</div>

//对于以上的代码,写成子选择器则最终背景颜色变化的只有第一个p标签.
#mu>p{
    margin-top: 10px;
    background-color: #cccc00;
}
//但是写成这样,也就是后代选择器,两个都有效
#mu p{
    margin-top: 10px;
    background-color: #cccc00;
}

相邻同胞选择器 可以定位同一个父元素下某个元素之后的元素

直接看代码理解

<h2>这是一个标题</h2>
 <p>Harry Knowles</p>
<p>Harry Knowles</p>

对于以上的代码如何用相邻同胞选择器让第一个p标签变色呢.

h2 + p{
    margin-top: 10px;
    background-color: #cccc00;
}

属性选择器

根据某个属性是否存在或者属性的值来寻找元素.如果属性有多个值,用空格分开

<h2 title="标题">这是一个标题</h2>

//使用属性选择器改变h2的背景颜色
h2[title]{
    background-color: #cccc00;
}

-----------------------------------------------------华丽的分割线-----------------------------------------------------------------

第二章能看的东西就这么多.我觉得内容太少了就把我看视频的笔记拿出来给大家看看

下面给出属性选择器另外一些写法.
*= 包含XXX
^= 首字母为xxx
$= 结束字符xxx

一个示例

<h2 title="a">这是一个标题</h2>
<h2 title="bba">这是一个标题</h2>
<h2 title="ab">这是一个标题</h2>

//比如这个会使第一个h2的标签背景变色,其他不变,另外两个可以试一下
h2[title~="a"]{
    background-color: #cccc00;
}

结构性伪类选择器

first-line 某个元素的第一行
first-letter:某个元素首个字母

<p>这是第一行的内容<br/>这是第二行</p>

//这里p元素的第一个标签背景会改变,第二个不变
p:first-line{
    background-color: #cccc00;
}

//这里第一个p元素的第一个字符会变成红色
p:first-letter{
    color: #dc143c;
}

x:before{ //在某元素之前添加
content:
}

<ul>
        <li>列表1</li>
        <li>列表2</li>
        <li>列表3</li>
    </ul>

//这里将会在ul列表的上方添加一个"加的内容"的文字
ul:before{
    content: "加的内容";
}

其他一些选择器

root:绑定到页面的根元素中 如果设置了root,那么body的作用域就只有内容区域,反之body沾满全屏()
not:如果想对某个结构元素使用样式,但想排除这个结构下面的子结构元素
empty:指定当前元素中内容为空白时使用的样式

x代表元素名称
x:first-child{}
x:last-child{}
x:nth-child(position){} 从上往下数 包括父级和子级 position可以是数字也可以是奇偶数等等可以表示位置的词语奇数(odd) 偶数(even)
x:nth-of-type(){}
x:nth-last-child(position){}从下往上数
nth-last-of-type 同上类似

这里写出root,not,x中的第三个,第四个示例.其他的一看便知.

root:

//以下的代码将会看到整个屏幕背景是黄色,body所设置的图片背景只会作用在<div>所占的空间
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        :root{
            background-color: fuchsia;
        }
    </style>
</head>
<body background="1.jpg">
    <div>哈喽,root</div>
</body>
</html>

not

    <div><p>哈喽,root</p></div>
    <div><h1>哈喽,root</h1></div>
    <div><h2>哈喽,root</h2></div>

 //以下代码将会使除了p标签之外的其他标签变色
div *:not(p){
            color: fuchsia;
        }

**x:nth-child(position){} **

 <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
    </ul>

//以下代码将会使第二个li标签也就是2的文字变色.
//PS:一开始我以为X的部分要写ul,并且position从0开始.这里并不是,锁着这里是有先决条件的.必须是同一个父元素下.
li:nth-child(2){
            color: fuchsia;
        }

x:nth-of-type(){}

       <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
    </ul>
//以下代码将会使li标签中奇数li标签字体变色.偶数为even.这里括号的条件并不局限于奇数和偶数
li:nth-of-type(odd){
            color: fuchsia;
        }

选择器的内容大概就这些.

相关文章

  • css选择器

    css1,2选择器 css3选择器

  • css3新增选择器

    css3新增选择器 CSS3新增了许多灵活查找元素的方法,极大的提高了查找元素的效率和精准度。CSS3选择器与 j...

  • 初级了解css3伪类选择器

    在 CSS3 中,选择器是一种模式,用于选择需要添加样式的元素。 先来了解一下css3选择器的分类 css3选择器...

  • 2019前端经典面试题 CSS 部分常见问题

    CSS部分常见问题 1、CSS3选择器有哪些? 答:属性选择器、伪类选择器、伪元素选择器。 2、CSS3新特性有哪...

  • CSS3-目录

    1 CSS3 兼容性 2 CSS3 选择器 3 CSS3 新加属性 4 CSS3 过渡动画 5 CSS3 变型 6...

  • HTML5和CSS3新增内容

    CSS3选择器有哪些? 属性选择器、伪类选择器、伪元素选择器。 CSS3新特性有哪些? 颜色:新增RGBA,HSL...

  • 《图解CSS3》学习记录(01-概述)

    CSS3规范重复了部分CSS的内容,并在其基础上进行了很多增补和修改。 CSS3新特征: 1、强大的CSS3选择器...

  • CSS3知识概要总结之选择器篇(二)

    是的,从这里开始我们就开始学习CSS3的选择器了,学习资源CSS3选择器 属性选择器 属性选择器 发现属性选择器真...

  • jQuery选择器

    jQuery选择器支持CSS1、CSS2的全部和部分CSS3选择器,同时也拥有少量独有的选择器。jQueryt选择...

  • CSS3

    CSS3 新增选择器 CSS3 中,相对于 CSS2.1 版本的 7 个选择器,增加了更多其他的选择器,实现了更多...

网友评论

    本文标题:CSS和CSS3选择器

    本文链接:https://www.haomeiwen.com/subject/zzxqnttx.html