Flex的CSS样式优先级公式.docx
0.css 样式优先级公式 最近正在看 CSS 实战手册这本书,发现第五章管理多种样式中的样式优先级公式挺实用的。 有时候我们给同样一个属性用多种方式去定义样式,来自最具体的样式的属性会胜出,但不知道到底哪种样式最具体,好在 css 还提供了一个公式,他根据指派给样式选择器的值决定样式的特性 标签选择器、类选择器、 ID 选择器,等等。这个系统是这样进行的 1.一个标签选择器值 1 分。 2.一个类选择器值 10。 以“ .” 开头定义如 .demo --具体到如 这个区域字体颜色为红色 同时,我们可以再定义一个元素 这个段落字体颜色为红色 最后,用 浏览器 浏览,我们可以发现所有 class 为 demo 的元素都应用了这个样式。包括了页面中的 div 元素和 p 元素。 上例我们给两个元素都定义了 class,但如果有很多个元素都会应用这个元素,那得一个个的定义元素,就会造成页面重复的代码太多,这种现象称为 “ 多类症 ” 。 我们可以改成这样来定义。 这个区域字体颜色为红色 同时,我们可以再定义一个元素 这个段落字体颜色为红色 这样,我们就只是定义了一个类,同时把样式应用到了所有的元素当中。 1.2 标签选择器 一个完整的 HTML 页面是有很多不同的标签组成,而 标签选择器 ,则是决定哪些标签 采用相应的 CSS 样式, 在大环境中你可能出于不同的位置,但是不管怎么样,你总 是穿着同一套衣服,这件衣服就是由标签选择器事先给你限定好的,不管走到哪里 都是这身衣服 比如,在 style.css 文件中对 p 标签样式的声明如下 p{ font-size12px; background900; color090; } 复制代码则页面中所有 p 标签的背景都是 900红色 ,文字大小均是12px,颜色为 090绿色 ,这在后期维护中,如果想改变整个网站中 p 标签背景的颜色,只需要修改 background 属性就可以了,就这么容易 1.3 ID 选择器 根据元素 ID 来选择元素,具有 唯一性。 前面以 ”” 号来标志,在样式里面可以这样定义 demoDiv{ colorFF0000; } 这里代表 id 为 demoDiv 的元素的设置它的字体颜色为红色。 我们在页面上定义一个元素把它的 ID 定义为 demoDiv,如 这个区域字体颜色为红色 用浏览器浏览,我们可以看到因为区域内的颜色变成了红色 再定义一个区域 这个区域没有定义颜色 用浏览器浏览,与预期的一样,区域没有应用样式,所以区域中的字体颜色还是默认的颜色黑色。 1.4 后代选择器 后代选择器也称为包含选择器,用来选择特定元素或元素组的后代,后代选择器用两个常用选择器,中间加一个空格表示。其中前面的常用选择器选择父元素,后面的常用选择器选择子元素,样式最终会应用于子元素中。 如 .father.child{ color0000CC; } 黑色 蓝色 也是蓝色 这里我们定义了所有 class 属性为 father 的元素下面的 class 属性为child 的颜色为蓝色。后代选择器是一种很有用的选择器,使用后代选择器可以更加精确的定位元素。 1.5 子选择器 请注意这个选择器与后代选择器的区别,子选择器( child selector)仅是指它的直接后代,或者你可以理解为作用于子元素的第一个后代。而后代选择器是作用于所有子后代元素。后代选择器通过空格来进行选择,而子选择器是通过 “” 进行选择,我们看下面的代码 Example Source Code CSS links a {colorred;} links a {colorblue;} HTML DivCSS 教程 CSS 布局实例 CSS2.0 教程 我们将会看到第一个链接元素 “DivCSS 教程 ” 会显示成蓝色,而其它两个元素会显示成红色。当然,或许你的浏览器并不支持这样的 CSS 选择符。我们在一开始也强调了不太兼容的现状。 子选择器( )和后代选择器(空格)的区别都表示 “ 祖先 -后代 ”的关系,但是 必须是 “ 爸爸 儿子 ” ,而空格不仅可以是 “ 爸爸儿子 ” ,还能是 “ 爷爷儿 ” 、 “ 太爷爷儿子 ” 。 1.6 伪类选择器 有时候还会需要用文档以外的其他条件来应用元素的样式,比如鼠标悬停等。这时候我们就需要用到伪类了。以下是链接应用的伪类定义。 alink{ color999999; } avisited{ colorFFFF00; } ahover{ color006600; } /* IE 不支持,用 Firefox 浏览可以看到效果 */ focus{ background E0F1F5; } Link 表示链接在没有被点击时的样式。 Visited 表示链接已经被访问时的样式。 Hover 表示当鼠标悬停在链接上面时的样式。 伪类不仅可以应用在链接标签中,也可以应用在一些表单元素中,但表单元素的应用 IE 不支持,所以一般伪类都只会被应用在链接的样式上。 1.7 通用选择器 通用选择器用 *来表示。例如 *{ font-size 12px; } 表示所有的元素的字体大小都是 12px;同时通用选择器还可以和后代选 择器组合。 例如 p *{ „„ } 表示所有 p 元素后代的所有元素都应用这个样式。但是与后代选择器的搭配容易出现浏览器不能解析的情况,比如像这样子 所有的文本都被定义成红色 所有这个段落里面的子标签都会被定义成蓝色 所有这个段落里面的子标签都会被定义成蓝色 所有这个段落里面的子标签都会被定义成蓝色 所有这个段落里面的子标签都会被定义成蓝色 这个例子里面 p 标签里面嵌套了一个 p 标签,这个时候样式可能会出现与预期结果不相同的结果。 1.8 群组选择器 当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔。如 p, td, li { line-height20px; colorc00; } main p, sider span { color000; line-height26px; } .www_52css_com,main p span { colorf60; } .text1 h1,sider h3,.art_title h2 { font-weight100; } 使用群组选择器,将会大大的简化 CSS 代码,将具有多个相同属性的元素,合并群组进行选 择,定义同样的 CSS 属性,这大大的提高了编码效率,同时也减少了 CSS 文件的体积。 1.9 相邻同胞选择器 我们除了上面的子选择器与后代选择器,我们可能还希望找到兄弟两个当中的一个,如一个标题 h1 元素后面紧跟了两个段落 p 元素,我们想定位第一个段落 p 元素,对它应用样式。我们就可以使用相邻同胞选择器。看下面的代码 Example Source Code CSS h1 p {colorblue} HTML 一个非常专业的 CSS 站点 DivCSS 教程中,介绍了很多关于 CSS 网页布局的知识。 CSS 布局实例中,有很多与 CSS 布局有关的案例。 我们将会看到第一个段落 “DivCSS 教程中,介绍了很多关于 CSS 网页布局的知识。 ” 文字颜色将会是蓝色。而第二段则不受此 CSS 样式的影响。 和 的区别类似上面一个,两者都表示兄弟关系,但是 必须是 “ 大哥 二哥 ” , 还能是 “ 大哥 三弟 ” 、 “ 二哥 四妹 ” 1.10 属性选择器 您可以用判断 html 标签的某个属性是否存在的方法来定义 css 例如 abbr[title]{ colorFF0000; } 表示 abbr 标签是否有 title 属性,如果有则应用这个样式。 也可以用判断 html 标签的某个属性值的方法来定义 css 例如 p[title app ]{ colorFF0000; } 这里所有 p 标签中, title 属性为 app 的都会应用这个样式。 1.11 总结 css3 定义中有更多的选择器类型,但由于各浏览器支持不一,所以不推荐使用,在此不详细叙述。