分享人:郭健锋
目录
1.背景介绍
2.知识剖析
3.常见问题
4.解决方案
5.编码实战
6.扩展思考
7.参考文献
在我们深入探讨继承之前,有必要先理解文档树。所有的HTMl文档都是树,文档树由HTML元素组成,文档树和家族树类似,也有祖先、后代、父亲、孩子、兄弟
祖先指任意相连,但是在文档树上部的元素。
后代指任意相连,但是在文档树下部的元素。
父辈指相连并且直接在该元素上部的元素。
子辈指相连并且直接在该元素下部的元素。
兄弟指与其他元素共享一个父辈的元素。
除此之外还有必要先知道CSS的规则,CSS规则告诉浏览器如何去渲染HTML页面上的特定元素。
1:选择器“选择”受此规则影响的HTML页面上的元素。
p { color: red ;}
//Selector
2:声明部分是由一对大括号以及其中任意内容组成的容器。
p { color: red ;}
//Declaration block
3:声明告诉浏览器如何去渲染页面上被选中的元素。
p { color: red ;}
//Declaration
4:属性告诉你选中元素的样式外观。
p { color: red ;}
//Property
5:值是你希望给属性设置准确的样式。
p { color: red ;}
//Value
现在我们可以进入正题了。
css样式表继承指的是,特定的css属性向下传递到后代元素
为了看到继承的实际应用,我们将使用下面的HTML代码。
Lorem ipsum dolor sit amet consect etuer.
注意: em元素在 p元素的内部。
我们也使用CSS代码。注意:em元素未指定样式。
p { color: red ;}
在浏览器中, p元素和 em元素同时变红。
但是为什么em元素会变红?其并没有设置颜色样式。
因为em元素继承了p元素的颜色属性。
继承是网页开发者更加轻松,否则我们就要对所以的子孙元素指定属性。
p { color: red ;}
p em{ color: red ;}
CSS文件大小将会大大增加,变得更难创建与维护,同时降低了下载速度。
是否所以的CSS属性都可以继承呢?
非也!并非所以的CSS属性都支持继承。
如果每个CSS属性都继承,对于作者而言,反而会让事情更糟。
开发人员需要将子孙元素不需要的CSS属性一个一个地“关掉”。
我们可以设想下,如果默认状态下,border属性是可以继承的...
然后我们将border属性应用于p元素,结果?
p { border: 1px solid red;}
结果在p里面em元素也有了红色边框。
幸运的是,边框是非继承的,所以em元素是没有边框的。
通常来说,仅仅那些使我们工作轻松的属性是继承的。
那么有哪些属性可以自动继承呢
有继承性的属性:
1、字体系列属性 font:组合字体 font-family:规定元素的字体系列 font-weight:设置字体的粗细 font-size:设置字体的尺寸 font-style:定义字体的风格 font-variant:设置小型大写字母的字体显示文本,这意味着所有的小写字母均会被转换为 大写,但是所有使用小型大写字体的字母与其余文本相比,其字体尺寸更小。 font-stretch:允许你使文字变宽或变窄。所有主流浏览器都不支持。 font-size-adjust:为某个元素规定一个 aspect 值,字体的小写字母 "x" 的高度与 "font-size" 高度之间的比率被称为一个字体的 aspect 值。这 样就可以保持首选字体的 x-height。
有继承性的属性:
2、文本系列属性 text-indent:文本缩进 text-align:文本水平对齐 line-height:行高 word-spacing:增加或减少单词间的空白(即字间隔) letter-spacing:增加或减少字符间的空白(字符间距) text-transform:控制文本大小写 direction:规定文本的书写方向 color:文本颜色
有继承性的属性:
3、元素可见性:visibility 4、表格布局属性:caption-side、border-collapse、border-spacing、 empty-cells、table-layout 5、列表属性:list-style-type、list-style-image、list-style-position、list-style 6、生成内容属性:quotes 7、光标属性:cursor 8、页面样式属性:page、page-break-inside、windows、orphans 9、声音样式属性:speak、speak-punctuation、speak-numeral、speak-header、 speech-rate、volume、voice-family、pitch、pitch-range、 stress、richness、、azimuth、elevation
所有元素可以继承的属性:
1、元素可见性:visibility、opacity 2、光标属性:cursor内联元素可以继承的属性:
1、字体系列属性 2、除text-indent、text-align之外的文本系列属性块级元素可以继承的属性:
1、text-indent、text-align
无继承的属性
1、display 2、文本属性:vertical-align: text-decoration: text-shadow: white-space: unicode-bidi: 3、盒子模型的属性:宽度、高度、内外边距、边框等 4、背景属性:背景图片、颜色、位置等 5、定位属性:浮动、清除浮动、定位position等 6、生成内容属性:content、counter-reset、counter-increment 7、轮廓样式属性:outline-style、outline-width、outline-color、outline 8、页面样式属性:size、page-break-before、page-break-after
继承中比较特殊的几点
1、a 标签的字体颜色不能被继承
1、<h1>-<h6>标签字体的大下也是不能被继承的
因为它们都有一个默认值
font-size的继承是如何实现的?
实例一:像素
p 元素设置了14px的font-size大小。
p { font-size:14px;}
改像素值(14px)重写了浏览器默认的font-size大小。在这个新值被后代继承了。
实例二:百分比
p 元素设置了85%的font-size大小。
p { font-size:85%;}
浏览器默认的font-size大小和百分比值被用来生成计算后的值。在这个新值被后代继承了。
实例三:em单位
p 元素设置了0.85em的font-size大小。
p { font-size:.85em;}
浏览器默认的font-size和em值(.85em)被用来生成计算后的值。在这个新值被后代继承了。
开发者如何使用继承书写高效的CSS代码。
例如,你可以设置color,font-size和font-family在body元素上。
body {
color:#222;
font-family:arial,helvetica,sans-serif;
font-size:90%;
}
这些属性会被继承到所有后代元素上。
然后你可以重写你需要的属性值,制定性的颜色值
h1,h2,h3 {color:green;}
h4,h5,h6 {color:black;}
新的font-family值
h1,h2,h3,h4,h5,h6 {font-family:georgia,times,serif;}
以及需要的font-size值。
h1{ font-size: 200%; }
h2{ font-size: 150%; }
h3{ font-size: 125%; }
#footer{ font-size: 90%;}
参考一:CSS之继承详解
感谢大家观看
BY : 郭健锋