一 继承性

  css有两大特性:继承性和层叠性

  面向对象语言都会存在继承的概念,在面向对象语言中,继承的特点:继承了父类的属性和方法。那么我们现在主要研究css,css就是在设置属性的。不会牵扯到方法的层面。

  继承:给父级设置一些属性,子级继承了父级的该属性,这就是我们的css中的继承。

  记住:有一些属性是可以继承下来 : color 、 font-*、 text-*、line-* 。主要是文本级的标签元素。

  但是像一些盒子元素属性,定位的元素(浮动,绝对定位,固定定位)不能继承。

  
 

二 层叠性

  层叠性: 权重大的标签覆盖掉了权重小的标签,说白了 ,就是被干掉了
  权重: 谁的权重大,浏览器就会显示谁的属性

  谁的权重大? 非常简单就是小学的数数。

  数:id的数量 class的数量 标签的数量,顺序不能乱

/*1  0  0 */显示红色
#box{ color: red;
}
/*0 1 0*/
.container{
color: yellow;
}
/*0 0 1*/
p{
color: purple;
}

  是不是感觉明白了呢?好的,再给大家加深点难度。

1     <div id='box1' class="wrap1">
2 <div id="box2" class="wrap2">
3 <div id="box3" class="wrap3">
4 <p>再来猜猜我是什么颜色?</p>
5 </div>
6 </div>
7 </div>

  

        #box1 #box2 p{
color: yellow;
} #box2 .wrap3 p{
color: red;
} div div #box3 p{
color: purple;
} div.wrap1 div.wrap2 div.wrap3 p{
color: blue;
}

  好的。那么上面的这个案例大家是否懂了呢?那么接下来我们继续看案例

  还是上面那个html结构,如果我设置以下css,会显示什么颜色呢。

1         #box2 .wrap3 p{
2 color: yellow;
3 }
4
5 #box1 .wrap2 p{
6 color: red;
7 }

  答案是红色的。结论:当权重一样的时候 是以后来设置的属性为准,前提必须权重一样 。‘后来者居上 ’。

  Good,我们继续看下面的css,你来猜以下此时字什么颜色?

#box1 #box2 .wrap3{
color: red;
} #box2 .wrap3 p{
color: green;
}

  答案是绿色。哈哈,是不是感觉快懵掉了。其实大家只要记住这点特性就可以。第一条css设置的属性值,是通过继承性设置成的红色,那么继承来的属性,它的权重为0。它没有资格跟我们下面选中的标签对比。

  那大家猜想一下如果都是被继承来的属性,那么字会显示什么颜色呢?

#box1 #box2 .wrap3{
color: red;
}
.wrap1 #box2{
color: green;
}

  小案例证明:权重都是0:那么就是"就近原则" : 谁描述的近,就显示谁的属性。所谓描述的近,就是选中到最内层的距离越近。

  总结:
    1.先看标签元素有没有被选中,如果选中了,就数数 (id,class,标签的数量) 谁的权重大 就显示谁的属性。权重一样大,后来者居上
    2.如果没有被选中标签元素,权重为0。
  如果属性都是被继承下来的 权重都是0 。权重都是0:"就近原则" : 谁描述的近,就显示谁的属性

三 层叠性权重相同处理

  直接上代码,看效果!

  第一种现象:当权重相同时,以后来设置的属性为准,前提一定要权重相同

#box2 .wrap3 p{
color: yellow;
} #box1 .wrap2 p{
color: red;
}

  我们会发现此时显示的是红色的。

  第二种现象: 第一个选择器没有选中内层标签,那么它是通过继承来设置的属性,那么它的权重为0。第二个选择器选中了内层标签,有权重。

  所以 继承来的元素 权重为0。跟选中的元素没有可比性。

#box1 #box2 .wrap3{
color: red;
}
#box2 .wrap3 p{
color: green;
}

  我们会发现此时显示的是绿色的。

  第三种现象:如果都是继承来的属性,谁描述的近,显示谁的属性。'就近原则'

#box1 #box2 .wrap3{
color: red;
}
.wrap1 #box2{
color: green;
}

  !important 的使用。

  !important:设置权重为无限大 
  !important 不影响继承来的权重,只影响选中的元素。不要随便使用!important,因为使用它会影响页面的布局

最新文章

  1. SQLSERVER如何使用递增排序的GUID做主键
  2. asp.net发邮件功能
  3. redis主从复制搭建
  4. kali 密码攻击
  5. PHP 开发 APP 接口 学习笔记与总结 - Redis 缓存
  6. SqlSever基础 rtrim函数 除去字符串的右边的空格,左边中间的不管
  7. Queue 应用——拓扑排序
  8. select绑定json数组对象 asp.net
  9. [jobdu]数组中的逆序对
  10. WebConfig加密解密
  11. 17.2.2 Replication Relay and Status Logs 复制Relay 和状态日志;
  12. 转载文章:Windows Azure 基础结构服务上的 Microsoft Dynamics NAV 和 Microsoft Dynamics GP!
  13. 14.4.3.6 Fine-tuning InnoDB Buffer Pool Flushing 微调 InnoDB Buffer Pool 刷新:
  14. C# TextBlock 上标
  15. EHDU-1039 asier Done Than Said?
  16. Ruby面向对象
  17. python基础(2)-运算符&amp;while循环
  18. collection.Counter
  19. 图集内子图压缩及 ETC2 fallback选项的作用
  20. Java抓任意网页标题乱码jsoup解决方案一例

热门文章

  1. 开源代码MyCommons
  2. [redis]复制机制,调优,故障排查
  3. 算法图解学习笔记01:二分查找&amp;大O表示法
  4. 关于莫比乌斯函数的塞 : 莫比乌斯前n项和 , 莫比乌斯函数绝对值的前n项和
  5. mono 的System.Data.SqlClient小记录
  6. MFRC522开发笔记
  7. redis 数据持久化 aof方式
  8. @SafeVarargs注解
  9. Chapter 3. Lexical Structure
  10. Javac之Environment