CSS三大特性—— 继承、 优先级和层叠。

继承:即子类元素继承父类的样式;

优先级:是指不同类别样式的权重比较;

层叠:是说当数量相同时,通过层叠(后者覆盖前者)的样式。

css选择符分类  

首先来看一下css选择符(css选择器)有哪些?

  1.标签选择器(如:body,div,p,ul,li)

  2.类选择器(如:class="head",class="head_logo")

  3.ID选择器(如:id="name",id="name_txt")

  4.全局选择器(如:*号)

  5.组合选择器(如:.head .head_logo,注意两选择器用空格键分开)

  6.后代选择器 (如:#head .nav ul li 从父集到子孙集的选择器)

  7.群组选择器 div,span,img {color:Red} 即具有相同样式的标签分组显示

  8.继承选择器(如:div p,注意两选择器用空格键分开)

  9.伪类选择器(如:就是链接样式,a元素的伪类,4种不同的状态:link、visited、hoveractive。注意:必须将伪类写在本身选择器之后,并且是伪类也有顺序link、visited、hoveractive,就是LVHA,这个叫爱恨原则,LoVe/HAte)

  10.字符串匹配的属性选择符(^ $ *三种,分别对应开始、结尾、包含)

[attribute^=value] a[src^="https"] 选择其 src 属性值以 "https" 开头的每个 <a> 元素。  
[attribute$=value] a[src$=".pdf"] 选择其 src 属性以 ".pdf" 结尾的所有 <a> 元素。  
[attribute*=value] a[src*="abc"] 选择其 src 属性中包含 "abc" 子串的每个 <a> 元素

  11.子选择器 (如:div>p ,带大于号>)

  12.CSS 相邻兄弟选择器器 (如:h1+p,带加号+)

css优先级

当两个规则都作用到了同一个html元素上时,如果定义的属性有冲突,那么应该用谁的值的,CSS有一套优先级的定义。

不同级别时:

  1. 在属性后面使用 !important 会覆盖页面内任何位置定义的元素样式。
  2. 作为style属性写在元素内的样式
  3. id选择器
  4. 类选择器
  5. 标签选择器
  6. 通配符选择器
  7. 浏览器自定义或继承

      总结排序:!important > 行内样式>ID选择器 > 类选择器 > 标签 > 通配符 > 继承 > 浏览器默认属性

同一级别:

选择器类别 说明 权重表示 权值表示
行内样式 行内只有一个 style = "" (1.0.0.0)  1000
id选择器 selector中使用了几个id,即#的个数 (0.1.0.0)    100
类选择器

类,伪类,以及属性的个数,如: .outerClass .buttonClass[type="button"]:hover{}

选择器中有2个类,1个属性,1个伪类(0.0.4.0)

(0.0.1.0)      10
元素选择器

伪元素和标签元素的个数,如: p:first-child

选择器中有一个标签元素p和一个伪元素first-child

(0.0.0.1)        1

注意:权值实际并不是按十进制,用数字表示只是说明思想,一万个class也不如一个id权值高

例子:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>cssTest</title>
<style type="text/css">
div.test{
background-color:black;
width:100px;
height: 100px;
}
/*权重为0011*/ .test.test2{
background-color:red;
width:100px;
height: 100px;
}
/*权重为0020*/ </style>
</head>
<body>
<div class="test test2"></div>
</body> </html>

根据选择器中规则对应做加法,比较权值,从左到右进行比较,大的优先级越高,如果权值相同那就后面的覆盖前面的了

之前有个面试官问我权重问题.题目如下:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>cssTest</title>
<style type="text/css">
div.test{
background-color:black;
width:100px;
height: 100px;
} .test{
background-color:red;
width:100px;
height: 100px;
} </style>
</head>
<body>
<div class="test test2"></div>
</body> </html>

div是什么颜色?

答案为黑色

div.test权重为0011,  .test的权重为0010,所以显示的是div.test的样式.

注意:

1.CSS选择器的使用,应该尽量避免使用 !important 和 内联样式;id通常也是与class区分开使用,前者多用于JS中的结点定位,后者多用于CSS选择器;

2.CSS选择器的解析原则是从右往左的,这样的好处是尽早的过滤掉一些无关的样式规则和元素 ;

3.不要再id选择器前使用标签名(id选择是唯一的,加上标签名相当于画蛇添足);

4.尽量少使用层级关系;

5.使用类选择器代替层级关系.

参考:

https://www.cnblogs.com/zxjwlh/p/6213239.html

https://www.cnblogs.com/nangezi/p/9042973.html

最新文章

  1. Leetcode-190 Reverse Bits
  2. linux中service *** start与直接运行/usr/bin/***的区别
  3. 当你的IIS需要运行ASP网站时,需要这样配置下你的IIS
  4. ZooKeeper与Curator注册和监控
  5. HTML5桌面通知(Web Notifications)实例解析
  6. DNA比对
  7. linux 输入子系统(3)----事件处理(input_handler层)
  8. jstat(JVM Statistics Monitoring Tool)
  9. Selenium索引
  10. 04747_Java语言程序设计(一)_第5章_图形界面设计(一)
  11. iOS加密个人见解
  12. servlet第2讲(上集)
  13. 【LeetCode】232. Implement Queue using Stacks
  14. JS时间处理由CST格式转成GMT格式时间
  15. Dynamics CRM 系统自定义部分的语言翻译
  16. [Swift]LeetCode845. 数组中的最长山脉 | Longest Mountain in Array
  17. 打造RecyclerView的n级列表
  18. mybatis教程2(配置文件)
  19. 安卓开发 1配置环境 (JDK+Andriod stiuio)
  20. Laravel上传产品图片Uploading img

热门文章

  1. Python异常捕捉的一个小问题
  2. 【DIP, 图像增强】
  3. Sublime Text 3配置支持Markdown编辑
  4. Android Studio Module 的添加与删除
  5. 导入数据到mysql的一种简单的方法
  6. 条款31: 千万不要返回局部对象的引用,也不要返回函数内部用new初始化的指针的引用
  7. 用WebCollector爬取新浪微博数据
  8. android开发艺术探索学习 之 结合Activity的生命周期了解Activity的LaunchMode
  9. 转 C# 将字符串转换为计算公式,并计算结果
  10. LeetCode 21. Merge Two Sorted Lists (合并两个有序链表)