css有哪些属性可以继承?

分享人:郭健锋

目录

1.背景介绍

2.知识剖析

3.常见问题

4.解决方案

5.编码实战

6.扩展思考

7.参考文献

1.背景介绍

在我们深入探讨继承之前,有必要先理解文档树。所有的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
            
            

2.知识剖析

现在我们可以进入正题了。

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文件大小将会大大增加,变得更难创建与维护,同时降低了下载速度。

3.常见问题

是否所以的CSS属性都可以继承呢?

非也!并非所以的CSS属性都支持继承。

如果每个CSS属性都继承,对于作者而言,反而会让事情更糟。

开发人员需要将子孙元素不需要的CSS属性一个一个地“关掉”。

我们可以设想下,如果默认状态下,border属性是可以继承的...

然后我们将border属性应用于p元素,结果?

            
                p { border: 1px solid red;}
            
            

结果在p里面em元素也有了红色边框。

幸运的是,边框是非继承的,所以em元素是没有边框的。

通常来说,仅仅那些使我们工作轻松的属性是继承的。

4.解决方案

那么有哪些属性可以自动继承呢

有继承性的属性:


        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>标签字体的大下也是不能被继承的

因为它们都有一个默认值

5.编码实战

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)被用来生成计算后的值。在这个新值被后代继承了。

6.扩展思考

开发者如何使用继承书写高效的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%;}
            
            

7.参考文献

参考一:CSS之继承详解

鸣谢

感谢大家观看

BY : 郭健锋