【转】刨根究底CSS(2):CSS中的各种值——初始值,就是默认值吗?

先问个非常简单的问题,这个问题的答案,相信大部分Web开发人员都自认为显而易见,但却又多半会答错:CSS属性中的初始值(initial value),就是默认值(default value)吗?

难道不对吗?请往下看。

默认值

默认值(default value)指的是没有显式地为CSS属性声明一个值的情况下,所默认使用的隐式缺省值。

注: 这里所说的默认值,并非各个浏览器自带的CSS默认值,为避免混淆,下面称浏览器默认值为浏览器自带值。

CSS规范中并未显式地明确定义默认值的概念,但根据对CSS规范的理解,可认为其隐式地定义了默认值,如下:

  • 对于非继承属性(CSS属性一览表[1]中inherited为no的属性),默认值为初始值initial;
  • 对于继承属性(CSS属性一览表中inherited为yes的属性):
  1. 若不是根元素(根元素是指:root选择器匹配到的元素,在html文档中一般指的是html元素,但也可能不是,以后专文介绍),则默认值为继承值inherit;
  2. 若是根元素,则默认值为初始值initial。

判断一个属性是不是继承属性,除了查询W3C官网上的CSS属性一览表,还有没有相对快捷的方法呢?

有的,大致上来说:

  • 跟文本、声音等与内容相关的属性,比如font、color、text-align、line-height、white-space、speak、voice-family、volume等属性,都是可继承属性;
  • 跟框模型、定位等与布局相关的属性,比如background、border、display、float、height、left、overflow、vertical-align、z-index等属性,都是非继承属性。
注意: 在实践中,由于各个浏览器会设定某些常用元素的常用CSS属性的值(即前文所述的浏览器自带值),因此只有在浏览器并没有显式地设定其值,并且其他各级样式(包括元素的style属性所设置的行间样式)也没有显式地设定其值的情况下,才会最终使用上述的默认值。

初始值

在W3C CSS规范的每个CSS属性定义表中,已经给出了属性的初始值(initial value),如下图所示。

初始值对于继承属性和非继承属性[2],有着不同的含义:

  • 对于继承属性,初始值只能被用于没有指定值的根元素上;
  • 对于非继承属性,初始值可以被用于没有指定值的任意元素上。

在CSS 3中,允许使用initial关键词明确地设定初始值,也就是说,关键词initial代表初始值,不过目前各浏览器对关键词initial的支持情况较差,可通过http://caniuse.com查看具体的支持情况。

继承值

每个CSS属性定义表中,都指出了这个属性是默认继承的("Inherited: Yes"),还是默认不继承的("Inherited: no")(可参看W3C的CSS属性全表Full property table[3])。

继承值(inherit value)决定了当没有为元素的属性手动设置其值时该如何确定其值。

当元素的一个继承属性 没有手动设置其值时,则取父元素相同属性的计算值computed value[4],该值即为继承值。

注意,子元素不直接继承为其父元素所指定的相对数值,而是继承其父元素经过计算之后的数值——计算值,可能是绝对数值,也可能仍然还是相对数值,详见下文对计算值的介绍。

比如,在以下规则中,如果"h1"是"body"元素的子级,则"h1"元素所继承的"text-indent"属性值将为36px,而不是3em,因此最终其值不会是45px:

 body {font-size: 12px;text-indent: 3em;  /* 计算值为36px */}h1 { font-size: 15px; }

下面的示例中,P元素的子元素继承的"line-height"的值为12px,而不是百分比值(120%):

p {font-size: 10px;line-height: 120%;
}

但文档根元素由于没有父元素,如果在根元素上为某个CSS属性设置了inherit值,则会取该属性在CSS规范中所定义的初始值[5](但如果设置了浏览器自带值,则取浏览器自带值)。

声明值

为每个属性显式地声明的值(或者说设置的值),称之为声明值(declared value),或称之为设置值。

声明值可能是程序员手动显式声明的值(包括内联样式、外部样式、行间样式中所声明的值),也可能是浏览器显式设置的浏览器自带值。

声明值是相对于默认值而言的,如果一个CSS属性在各级样式(包括浏览器自带样式、内联样式、外部样式、行间样式)中都没有显式的声明值,则使用隐式的默认值。

层叠值

层叠值(cascaded value),也译作级联值,指的是对多个来源的各级样式(包括浏览器自带样式、浏览器用户自定义样式、内联样式、外部样式、行间样式)的默认值或声明值进行层层叠加计算后的结果值。

该结果值是参与层叠计算的样式值中符合层叠计算规则的优先级最高的值,要么是某级样式中的一个默认值,要么是某级样式中的一个声明值。

这也就是“CSS层叠样式表”这个名称的来源。

因此,层叠值的计算相当于各级样式优先级的计算,最后以优先级最高的为准。

层叠值的计算,涉及到样式的来源origin、重要性important、特殊性specificity,需遵循CSS层叠规则。

一个元素某个CSS属性的层叠值,在按层叠计算规则计算之后,如果该属性最终有“胜出的”声明值,则该值为层叠值。

层叠计算规则比较复杂,后面将专文进行介绍。

指定值

CSS属性的指定值(specified value)通过以下途径获取:

  • 如果当前文档的各级样式层叠后的层叠值不是空值,则该层叠值为指定值。例如:各级样式层叠计算后,color属性的值为green,则green为color属性的指定值;
  • 否则,如果层叠值是空值,则以该属性的默认值作为指定值。具体而言:
  1. 如果该属性为继承属性,并且其所在元素不是文档的根元素,则使用父元素的计算值作为指定值。例如:在一个<div>内部放置一个段落<p>,这个<div>的font属性的计算值为"Arial",而<p>的font属性属于继承属性,那么它的font属性的指定值就会继承为Arial;
  2. 如果该属性为非继承属性,或是文档根元素的属性,则将CSS规范中针对该属性所定义的初始值initial value作为指定值。

这样,指定值就保证了为每个元素的每个CSS属性都一定指定了一个值。

计算值

一个CSS属性的计算值(computed value)通过以下方式获得:

  • 处理特殊的值:inherit、initial、unset和revert;以及
  • 进行计算,以达到属性定义表中“计算值Computed Value”所描述的值。

达到属性"计算值"所需的计算,通常涉及到相对计算,也就是将相对比值(如em单位或百分比值)转换成绝对数值的计算过程。

例如,一个元素具有声明值为:font-size: 16px和padding-top: 2em,则padding-top的计算值为32px(字体大小的2倍)。

然而,有些属性的百分比值会转换成百分比的计算值,也就是说,计算后还是百分比值,因此仍然是相对比值,而不是绝对数值,因为这些元素的百分比值是相对于需要布局后才能知道的值,如width、margin-right、text-indent和top等。

另外,line-height属性值如果是不带单位的数字值(这属于相对比值),则该值就是其计算值。

这些计算值中的相对比值会在使用值(used value)确定后再被转换成绝对数值。

计算值通常是为了在继承的准备过程中对属性值尽可能进行绝对化。当然,也只是尽可能而已,如上所述,计算值仍然有可能是相对比值,而不是绝对数值。

注意: 由于历史原因,CSS 2.1之后,计算值不一定是[Window.getComputedStyle()](https://developer.mozilla.org/zh-CN/docs/Web/API/Window/getComputedStyle "Window.getComputedStyle( "Window.getComputedStyle()")") 函数返回的值,所以该函数所返回的值被称之为“解析值”(详见下文解释),而不是“计算值”,虽然有时候返回的值确实就是计算值。

使用值

CSS属性的使用值(used value)是在取得计算值,并完成剩余计算(如果有的话)后的结果值。

使用值一定是绝对数值,这一点与计算值仍然有可能是相对比值是不同的。

相对于下面要提到的实际值(actual value)而言,使用值是文档布局中所使用的理论值。

如果一个属性不适用于某个元素,则该元素没有这个属性的使用值(但其计算值很可能仍然是存在的,只是会被忽略)。比如,flex属性在非flex项目的元素上没有使用值。

计算出CSS属性的使用值,有如下三个步骤:

  1. 首先,指定值(specified value)来自于各级样式层叠后的层叠值(即选取各级样式里权重最高的规则),继承值(如果是继承属性,且默认值为inherit),或者初始值。
  2. 然后,按规范计算出计算值,如span指定position属性的值为absolute后,其display属性的值变为block。
  3. 最后,计算布局(尺寸比如为auto或百分数则换算为像素值),计算结果即为使用值。

这些计算步骤是在内部完成的,JavaScript脚本只能使用Window.getComputedStyle()获得最终计算后的使用值(通过Window.getComputedStyle()获得的值,还有可能是计算值,具体请看下文对解析值resolved value的解释)。

使用值示例

  • 没有设置明确的宽度,则宽度的指定值为auto(默认),计算值为auto,使用值为998px (举例而言);
  • 设置了明确的宽度为50%,则宽度的指定值为50%,计算值为50%,使用值为447px;
  • 设置了明确的宽度为inherit,则宽度的指定值为50%(举例而言),计算值为50%,使用值为221px。

使用值与计算值的区别

CSS 2.0只定义了计算值作为属性计算的最后一步。CSS 2.1引进了定义明显不同的使用值,这样当父元素的计算值为百分比值时,比如上述示例中的宽度值,子元素仍然可以显式地继承该值。

对于不依赖于布局的CSS属性(例如display、font-size、line-height),其计算值与使用值一样,否则就会不一样。

解析值

CSS属性的解析值(resolved value)是Window.getComputedStyle()返回的值。

对于大多数属性,解析值等于其计算值,但对于一些旧属性,比如width、height等,它等于其使用值。

实际值

一个CSS属性的实际值(actual value),是使用值(used value)被使用后的近似值。

例如,浏览器可能只能渲染一个整数像素值的边框,而该整数像素值(实际值)可能是一个小数值(使用值)被强制四舍五入取整之后的近似结果值。

下表为W3C CSS规范[6]上的示例(表中的Winning declaration为层叠计算后最终“胜出的”属性声明值):


参考资料

[1] CSS属性一览表: https://www.w3.org/TR/CSS21/propidx.html

[2] 继承属性和非继承属性: https://developer.mozilla.org/en-US/docs/CSS/inheritance

[3] CSS属性全表: https://www.w3.org/TR/CSS21/propidx.html

[4] 计算值: https://developer.mozilla.org/en-US/docs/CSS/computed_value

[5] 初始值: https://developer.mozilla.org/en-US/docs/CSS/initial_value

[6] W3C CSS 规范: https://www.w3.org/TR/css-cascade-3/#stages-examples

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/437479.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

台式机电脑配置单_2020年电脑配置单重点硬件参考

&#xff0c;电脑的基本配件扫盲我前面写过很多&#xff0c;相信很多小伙伴都看过了&#xff0c;没有看过的可以上我专栏参观&#xff1a;电脑神棍局-组装机专栏​www.zhihu.com配置单在本文后面两篇&#xff0c;但是建议前面花两分钟看下。游戏篇后续还有工作和视频工作站篇主…

【转】刨根究底字符编码之五——简体汉字编码方案(GB2312、GBK等)以及全角、半角、CJK

一、概述 1. 英文字母再加一些其他标点字符之类的也不会超过256个&#xff0c;用一个字节来表示一个字符就足够了(2^8 256)。但其他一些文字不止这么多字符&#xff0c;比如中文中的汉字就多达10多万个&#xff0c;一个字节只能表示256个字符&#xff0c;肯定是不够的&#…

开机cpu风扇声音大_联想拯救者R720笔记本,开机显示暗屏,二修机多故障完美修复...

【机器型号】拯救者R720-15(7代I5)【主板版号】NM-B191【故障现象】笔记本不开机接同行送修笔记本拯救者R720-15&#xff0c;7代I5的机器&#xff0c;同行描述说不开机。【维修过程】 拿到机器按下开关没反映&#xff0c;三下五除二&#xff0c;扒下这台电脑的衣服&#xff0c;…

【转】刨根究底字符编码之六——简体汉字编码中区位码、国标码、机内码、外码、字形码的区别及关系

GB2312、GBK、GB18030等GB系列汉字编码方案的具体实现方式是怎样的&#xff1f;区位码是什么&#xff1f;国标码是什么&#xff1f;内码、外码、字形码又是什么意思&#xff1f;它们是如何转换的&#xff0c;又为什么要这样转换&#xff1f; 下面以GB2312为例来加以说明。 一、…

公共链接url出错_SEO优化技巧:关于URL的优化方法

点击标题下「蓝色微信名」可快速关注URL优化需要遵循一些原则&#xff0c; 采用以下方法&#xff0c;网页的用户体验更佳&#xff0c;同时对搜索引擎更友好。01URL越短越好对于搜索引擎来说&#xff0c;只要URL不超过265Byte&#xff0c;收录就没有问题。如果使用几百个字母的U…

【转】刨根究底字符编码之七——ANSI编码与代码页

一、ANSI编码 1. 如前所述&#xff0c;在全世界所有国家和地区的文字符号统一编码的UCS/Unicode编码方案问世之前(UCS、Unicode后文有详细介绍)&#xff0c;各个国家、地区为了用计算机记录并显示自己的字符&#xff0c;都在ASCII编码方案的基础上&#xff0c;设计了各自的编…

Angular 下拉搜索框实现

今天有个需求要写一个下拉搜索框&#xff0c;本来是下拉框的&#xff0c;由于内容太多&#xff0c;所以添加一个查找功能。根据博客进行改写的。参考了他的基本框架进行实现。 效果图&#xff1a; 输入框右边的白色箭头图片下载地址 <td>xxxxxxx</td> <td sty…

新手前端练手网站_编程到底难不难学?新手入门选择哪种语言好?

以下内容适合的读者&#xff1a;想要学习编程的小白一.编程到底难不难学&#xff1f;对于这个问题我的回答是不知道&#xff0c;学会了编程的人会说好学&#xff0c;中途就放弃的人会说很难&#xff0c;任何知识想要掌握好都不是一件容易的事情。所以我决定用自己的实际行动来证…

【转】刨根究底字符编码之八——Unicode编码方案概述

Unicode编码方案概述 1. 前面讲过&#xff0c;随着计算机发展到世界各地&#xff0c;于是各个国家和地区各自为政&#xff0c;搞出了很多既兼容ASCII但互相之间又不兼容的各种编码方案(微软统一称之为ANSI编码&#xff0c;具体体现为各种ANSI代码页)。 这样一来&#xff0c;同…

Angular 自定义属性指令-禁止input框输入空格-以及删除复制内容中的空格

创建一个ts文件&#xff0c;并在module.ts中定义 import { Directive, ElementRef, HostListener, Input } from angular/core; import { FormGroup, FormControl, NgControl } from angular/forms; Directive({selector: [input-noSpace]}) export class NoSpace {constructo…

基于androidx的快速开发框架_Vue企业级优雅实战07框架开发03封装基于MockJS的模拟数据...

预览本文的实现效果&#xff1a;# giteegit clone gitgitee.com:cloudyly/dscloudy-admin-single.git# githubgit clone gitgithub.com:cloudyly/dscloudy-admin-single.gitgit checkout 05_MockJS本文主要内容&#xff1a;基于 Mock JS&#xff0c;优雅设计网络请求的模拟数据…

【转】Net Framework,Net Core 和 Net Standard 区别

前几天我在一个群里看到有关这方面的讨论&#xff0c;最后感觉讨论的不是很清晰&#xff0c;有幸的是我们的项目去年就开始迁移NetCore的调研了&#xff0c;我个人多多少少也是有过这方面的研究。下面我将说一下我自己对着三个的认识如果有不足的地方&#xff0c;请大家指出。 …

记录一次SQL优化,增加索引,随便写的当笔记了

写了一个SQL&#xff0c;前端往返时间大约1.7秒&#xff0c;最终优化到一共150毫秒左右&#xff0c;应该还可以更好一些 下面说的有点乱&#xff0c;有空再好好总结一下吧。参考文章里面写的还是比较好的&#xff0c;只不过没有组合查询。 参考链接&#xff1a;https://zhuan…

使用函数求最大公约数 pta_高中数学选修教材2-导数第6课时《函数的单调性与导数》教学设计...

选修2-2第一章1.3.1 函数的单调性与导数一、先复习一下&#xff0c;上节课讲到了利用导数求曲线的切线方程(点我)&#xff0c;咱们这节课接着讲利用导数判断函数的单调性。二、做出图像形象生动&#xff0c;让学生看到当斜率为正(亦是导数为正)的时候函数图像是上升的&#xff…

java程序员_Java程序员工资为什么这么高?

众多行业中&#xff0c;程序员当然属于高薪职业。无论是国内还是国外&#xff0c;IT行业的程序员、工程师&#xff0c;甚至连码农都要比其他行业的从业者的收入高很多&#xff01;尤其是作为IT界的“常青树”Java&#xff0c;原因是什么&#xff1f;01Java行业市场需求存在巨大…

【转】深入浅出OOP(六): 理解C#的Enums

MSDN定义&#xff1a;枚举类型&#xff08;也称为枚举&#xff09;为定义一组可以赋给变量的命名整数常量提供了一种有效的方法。 例如&#xff0c;假设您必须定义一个变量&#xff0c;该变量的值表示一周中的一天。 该变量只能存储七个有意义的值。 若要定义这些值&#xff…

usb接口供电不足_AMD RX 6000 系列显卡配备USB-C 接口,支持外接供电

IT之家 10 月 29 日消息 根据 AMD 的官方信息&#xff0c;新发布的 RX 6000 系列显卡进一步增强了显示能力&#xff0c;配备了 HDMI 2.1 接口、DP 1.4 接口和 USB-C 接口。AMD 表示&#xff0c;AMD Radeon 6000 系列显卡全部搭载 HDMI 2.1 VRR 接口&#xff0c;超大带宽支持最高…

【转】VS2005键盘布局_快捷键大全(总结了一些记忆的口诀)

VS快捷键对提高生产力有莫大帮助&#xff0c;本文将所有快捷键进行了重新整理归类&#xff0c;便于记忆。有缺失&#xff0c;不足之处&#xff0c;还请大家指出&#xff0c;谢谢 1、窗口快捷键 &#xff08;W代表Windows也就是窗口的意思&#xff09; CtrlW,A: 命令窗口&#…

mac securecrt程序无响应_如何重置mac上的系统管理控制器smc教程

虽然mac是一款十分高端的个人笔记本电脑&#xff0c;但是mac也会有出现故障的时候&#xff0c;比如风扇高速转动、键盘背光灯行为有些异常异常等等&#xff0c;那极有可能是你的系统管理控制器smc出现了问题&#xff0c;所以今天小编就来科普大家如何重置系统管理控制器smc。如…

bootstraptable treeGrid 懒加载_Java类加载机制及自定义加载器

一&#xff1a;ClassLoader类加载器&#xff0c;主要的作用是将class文件加载到jvm虚拟机中。jvm启动的时候&#xff0c;并不是一次性加载所有的类&#xff0c;而是根据需要动态去加载类&#xff0c;主要分为隐式加载和显示加载。隐式加载&#xff1a;程序代码中不通过调用Clas…