css能够获取到HTML结构上的元素,这个是怎么实现的了?

在我们看来这是个很神奇的事情,css可以写在页面之外,也可以写在页面内,而都不会影响到它去

获取这个元素,还有无论这个HTML结构多么复杂,这个css也能准确获取你所要的HTML元素,既然

那么强大,那么是不是实现过程也是很困难呢?

只能绝对说这个很很很很简单的。

这只要记住以下的选择符即可,噢,还有上一篇还介绍了些选择符

子选择符

选择所有作为E元素的子元素F。 E>F

例子:

<style>
p>a{
color: black;
}
</style> <p>火狐是个<a href="#">浏览器</a></p>

相邻选择符

选择紧贴在E元素之后F元素。E+F

<style>
p+p{
font-weight: bold;
}
</style> <p>火狐是个<a href="#">浏览器</a></p>
<p>IE是个坑爹的浏览器</p>

兄弟选择符

选择E元素所有兄弟元素F。E~F

        <style>
li~li{
color: red;
}
</style> <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>

这个选择符选择不包括自己之外所有F选择符。

id 及 class 选择符

<p id="p1"> 这是一个段落 </p>

        #p1 {
font-size:12px;
font-weight:bold;
}
<p class="p1"> 这是一个段落 </p>

        .p1 {
font-size:12px;
font-weight:bold;
}

id 选择器可以为标有特定 id 的 HTML 元素指定特定的样式。

在网页中,每个id名称中只能使用一次,不得重复。

与id 不同,class 允许重复使用。比如页面中的多个元素,都可以使用同一个样式定义。

伪类选择符

E:link 设置超链接a在未被访问前的样式。

E:visited 设置超链接a在其链接地址已被访问过时的样式。

E:hover 设置元素在其鼠标悬停时的样式。

E:active 设置元素在被用户激活(在鼠标点击与释放之间发生的事件)时的样式。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>伪类</title>
<style>
a:link{
color: #00ffff;
}
a:visited{
color: #000;
}
a:hover{
color: #ff7600;
}
a:active{
color: #eee;
}
</style>
</head>
<body>
<a href="#">click into</a>
</body>
</html>

注意:这个4个伪类选择符的顺序按照    link-visited-hover-active

顺序乱来会出现问题,这个问题请移步到上篇扩展内容

E:focus     设置元素在成为输入焦点(该元素的onfocus事件发生)时的样式。

使用在表单中或能获取光标的元素上。

    input:focus{
outline: 2px solid #ff7600;
} <input type="text">

E:lang(fr)     匹配使用特殊语言的E元素。很少用

匹配中英双版,可能要使用到。

p:lang(en){
font-size: 14px;
} <p>IE是个坑爹的浏览器</p>

E:not(s)     匹配不含有s选择符的元素E。

ul li:not(.li3){
color: #fff;
} <ul>
<li>大明的子女1</li>
<li>大明的子女2</li>
<li class="li3">大明的子女3</li>
<li>大明的子女4</li>
<li>大明的子女5</li>
<li>大明的子女6</li>
<li>大明的子女7</li>
<li>大明的子女8</li>
<li>大明的子女9</li>
<li>大明的子女10</li>
</ul>

E:root      匹配E元素在文档的根元素。常指html元素

p:root{
background: blue;
}

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

   ul:first-child{
font-size: 15px;
} <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被匹配;

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

ul:last-child{
color: blue;
}

最后一个li被匹配;

E:only-child

    body:only-child{
color: blue;
} <p>火狐是个<a href="#">浏览器</a></p>
<p>IE是个坑爹的浏览器</p> <input type="text">

input被匹配;

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

    ul:nth-child(1){
color: blue;
}

ul下的第一个li被匹配;

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

ul:nth-last-child(1){
color: blue;
}

ul的子元素li的倒数第一个被匹配到。

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

    li:first-of-type{
font-weight: bold;
}

同类型li的第一个被选中;

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

    li:last-of-type{
border: 1px solid #ddd;
}

同类型li的最后一个被选中;

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

    li:only-of-type{
font-weight: bold;
}

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

    li:nth-of-type(3){
font-weight: bold;
}

第三li被匹配;

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

    li:nth-last-of-type(3){
background: green;
}

倒数第三个被匹配;

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

E:checked  匹配用户界面上处于选中状态的元素E。 (用于input type为radio与checkbox时)

    input:checked{
width: 100px;
} <input type="checkbox" name="name" id="1">
<input type="checkbox" name="name" id="2">
<input type="checkbox" name="name" id="3">
<input type="checkbox" name="name" id="4">

E:enabled    匹配用户界面上处于可用状态的元素E。

E:disabled    匹配用户界面上处于禁用状态的元素E。

E:target     匹配相关URL指向的E元素。

ul li a:target{
color: red;
} <ul>
<li><a href="#nav1" id="nav1">导航一</a></li>
<li><a href="#nav2" id="nav2">导航二</a></li>
<li><a href="#nav3" id="nav3">导航三</a></li>
</ul>

这个一定要设置路径URL,不是不行。只能使用与锚点,就是本页跳转。

不过可以使用来代表激活状态,以前是需要js实现的。

ok~

扩展小知识:

接上一篇又补充一些,让我们对css的理解更加深刻。

层叠样式表

层叠是什么意思?为什么这个词如此重要,以至于要出现在它的名称里。

层叠可以简单地理解为冲突的解决方案。

优先级规则可以表述为

行内样式>ID样式>类别样式>标记样式

在复杂的页面中,某一个元素有可能会从很多地方获取样式,例如一个网站的某一级标题整体设置为使用绿色,而对某个特殊栏目

需要使用蓝色,这样在栏目中就需要覆盖通用的样式设置。在很简单的页面中,这样的特殊需求实现起来不会很难,但是如果网站

的结构很复杂,就完全有可能代码变得非常混乱,可能出现无法找到某个元素的样式来自于哪条规则的情况。因此,必须要充分理

解css中“层叠”的原理。

计算冲突样式的优先级是一个比较复杂的过程,并不仅仅是上面这个简单的优先级规则可以完全描述的。但是使用者可以把把握 一个大的

原则,就是“越特殊的样式,优先级越高”行内样式对指定的一个元素产生影响,非常特殊,ID是针对某个元素的,因此它一定比应用于多个

元素的类别样式特殊。特殊性越高的元素,优先级越高。

css之选择器篇的更多相关文章

  1. css中选择器的使用

    css是英文Cascading Style Sheets的缩写.它是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集)等文件样式的计算机语言.我们再将html比喻 ...

  2. CSS类选择器和ID选择器

    CSS类选择器和ID选择器皆允许以一种独立于文档元素的方式来指定样式,同时二者皆区分大小写. 区别如下: 第一:在同一个页面内,不允许有相同名字的id对象出现,但是允许相同名字的class 第二:当页 ...

  3. 2天驾驭DIV+CSS (技巧篇)(转)

     这是去年看到的一片文章,感觉在我的学习中,有不少的影响.于是把它分享给想很快了解css的兄弟们.本文是技巧篇. 基础篇[知识一] “DIV+CSS” 的叫法是不准确的[知识二] “DIV+CSS” ...

  4. 2天驾驭DIV+CSS (实战篇)(转)

     这是去年看到的一片文章,感觉在我的学习中,有不少的影响.于是把它分享给想很快了解css的兄弟们.本文是实战篇. 基础篇[知识一] “DIV+CSS” 的叫法是不准确的[知识二] “DIV+CSS” ...

  5. 2天驾驭DIV+CSS (基础篇)(转)

    这是去年看到的一片文章,感觉在我的学习中,有不少的影响.于是把它分享给想很快了解css的兄弟们. 基础篇[知识一] “DIV+CSS” 的叫法是不准确的[知识二] “DIV+CSS” 将你引入两大误区 ...

  6. 小tip: CSS后代选择器可能的错误认识——张鑫旭

    一.关于类选择器的一个问题 假设有下面一个面试题,CSS代码如下: .red { color: red; } .green { color: green; } HTML如下: <div clas ...

  7. CSS 从入门到放弃系列:CSS的选择器和优先级

    CSS的选择器和优先级 CSS的N种选择器 !important 其实这个玩意不算什么选择器,放在这只是为了突出这个选择器优先级或者说权重的从高到低而已.. 内联方式(行间样式) <div st ...

  8. CSS系列(7)CSS类选择器Class详解

    这一篇文章,以笔记形式写. 1,  CSS 类选择器详解 http://www.w3school.com.cn/css/css_selector_class.asp 知识点: (1)    使用类选择 ...

  9. CSS 属性选择器的深入挖掘

    CSS 属性选择器,可以通过已经存在的属性名或属性值匹配元素. 属性选择器是在 CSS2 中引入的并且在 CSS3 中得到了很好拓展.本文将会比较全面的介绍属性选择器,尽可能的去挖掘这个选择器在不同场 ...

随机推荐

  1. ORA-01439: column to be modified must be empty to change datatype

    修改数据库字段类型,但是由于数据表已经存在数据,无法修改: 显示错误:  写道 ORA-01439: column to be modified must be empty to change dat ...

  2. ABAP 日期时间函数

    HR_JP_MONTH_BEGIN_END_DATE CALL FUNCTION 'HR_JP_MONTH_BEGIN_END_DATE' EXPORTING IV_DATE = ' IMPORTIN ...

  3. C语言 1 << 0 是什么意思

    1 << 0 是把1 按2进制 左移0位,结果还是 1 ,2进制 0000 00011 << 1, 是把1 按2进制 左移1位,结果是2,2进制 0000 0010

  4. Lua.LearningLua.5-document-for-luaL_findtable-function

    Learning Lua: 5 - Document for luaL_findtable() function 文档中没有找到luaL_findtable()函数的说明,这里尝试补充. LUALIB ...

  5. Java如何将html转以后的字符转化成正常显示的字符

    String str = "“!@#¥%……&——+”";//“!@#¥%……&——+”  中文状态下的标点符号,进过html转换了 String convStr ...

  6. 【Android测试】【随笔】性能采集工具——小松鼠诞生记

    ◆版权声明:本文出自胖喵~的博客,转载必须注明出处. 转载请注明出处:http://www.cnblogs.com/by-dream/p/4945066.html 起因 去年刚加入TX的时候,我便接手 ...

  7. 恢复SQLSERVER被误删除的数据(转——收藏)

    恢复SQLSERVER被误删除的数据 摘自:http://www.cnblogs.com/lyhabc/p/3683147.html 曾经想实现Log Explorer for SQL Server的 ...

  8. 阿里云配置nginx+php+mysql

    #yum -y install php mysql mysql-server mysql-devel php-mysql php-cgi php-mbstring php-gd php-fastcgi ...

  9. 【html】:禁止鼠标事件

    <body oncontextmenu="return false" onselectstart="return false" ondragstart=& ...

  10. mysql主主复制(双主复制)配置步骤

    以前我们介绍的都是主从复制,这里给各位介绍一个双主复制了,下面都希望两个主服务器数据自动复制的话可参考一下此文章.   MySQL主主复制结构区别于主从复制结构.在主主复制结构中,两台服务器的任何一台 ...