返回列表 发新帖

列元素所用属性之谜

456.7k 9
swmozowtfl 发表于 2015-7-26 20:47:12|湖北 | 查看全部 阅读模式
在table表格元素中,有一个col元素(它还有一个孪生胞兄colgroup元素),在 w3c 标准中,这个元素被称为列元素,用于定义表格中的某些列中的表现形式,在现行及常见的教程中,认为col元素可以使用常见的全局属性,以及align、valign、width等属性(乃至html 4.1 及 5.0 规范文档中,也同意该元素可以使用全局属性),很多demo也用它来举例说明如何让表格中的某列居中对齐、右对齐或改变某列的文字颜色,而事实上在大家常年的实践中,已经证明了一个很恐怖的事情…align也好valign也罢,甚至连全局属性中的color属性都完全不起作用,这到底是发生了什么事。* G) X7 r) B( q% ?5 G
照例先上结论:
5 K' m- u: C# [+ }9 Z7 o" S3 m, b在 css 2 中,列元素就仅能使用border、background、width及visibility这四个属性,其它属性(如对齐及字色都无法生效)。1 ?& l$ H5 k* v3 ?6 n
ie6、ie7及ie8(q)遵循常见教程,可以使用各种对齐和文字相关设置。  F0 p, X5 [6 E% S/ l% z
ie9开始及现在所有常用非ie浏览器均支持:nth-child(n)选择器,可以用该选择器实现列选择,并支持所有全局 css 属性。+ I4 U) A& U: {( y, d+ N
ie8(s)无解(因为它不支持上述选择器),除第一条所描述的 4 个 css 属性之外,无法统一改变列的对齐及字色。
. c1 c: ]( f& z3 r) J而col及colgroup元素,除了对ie6、7、8进行兼容之外,已经没用了。% I3 l0 k6 e# {. k+ _; A2 ]6 q
为什么,这究竟是为什么……  T. D- Z( W* z
从比较简单而明显的角度说,所有元素的属性在未定义的情况下,都是“继承”,也就是与其父元素属性相同。而表格的 html 书写方式,是以行为基础的,单元格是行的子元素,但不是列的,所以它继承不到列的属性。
# ]2 r$ T5 F' S% k: H+ a( E从更根本的角度说,是 css 的工作模式所决定的。页面的一切表现均交由 css 进行计算和渲染,而 css 的基本工作方式遵循下面的步骤:
# |( o, ?' M" q* A9 p. R9 D& c解析样式表和文档
: ]) a$ F* N4 D* k, _对于文档中的每个元素:" l" K9 @% m( L' G
决定应用哪个 css 规则。
6 B, L- E; l5 s, Z使用这些规则做出 css 级联。7 g" x# r7 E6 S; I+ N
如果级联的结果是关键字“继承”(或继承的属性没有规定值),则进行继承3 ^1 t1 Z" n: r
执行计算(把’em’变成’px’等等)。在 css 2.1 中,getcomputedstyle()dom方法负责返回这些值。
9 g9 x) b: p& l( Q此时,每个元素的所有属性都会有一个值。1 b! f: M* _. ]5 p  O3 F: a1 [1 M
排列文档版式# L+ y, f) E! F+ d" C. W/ ~
绘制文档
5 h2 m' V9 l6 I/ t" p' B6 q6 ^) Y. N在这样的工作顺序下,因为列元素是display:table-column,而单元格元素是display:table-cell,他们之间的具体关系要到第三步才能确认,因为你需要计算某一个单元格横跨几列或几行,才能确定某一个单元格到底是第几列。而在那之前,也就是第二步的时候,每个元素的属性值都已经计算出来了!但你还不知道哪个单元是第几列,所以你没办法知道该列的值。, F1 A4 W/ ]: ?6 x
然后我做了一个很无聊的demo,使用上面说到的 css 3 选择器,选择所有偶数列的单元格,变成蓝色;而让所有第三列的单元格变成黄色。然后分别对 n 行 n 列的单元格进行合并操作(也就是第一行的第一个单元格占据3个单元格的,第二行的第二个单元格占据3个单元格,以此类推)。结果如下:9 t8 q/ h5 P. I9 A% ]
: f7 ~6 S8 R' e( r+ X5 b1 s
                               
登录/注册后可看大图

% D. u  {* @0 O% Y. R/ k) X) }8 }列元素所用属性之谜
! V6 f3 k" p6 n$ U% E' ^因为对单元格进行了列合并,而那个选择器的本质又是按照行而非列选择的,结果就变成上面那样了(没能在视觉上垂直渲染某一列)。
4 a( @* y; p( ?话虽这么说,但在脱离了表格布局那么多年的今天,在表格终于能够回归它本来的应用目的的今天,这种奇葩布局的表格应该也是寥寥无几了。. @! J/ I& ]% T/ U/ R+ Q9 `: Y- K  \
, V; _* R0 A+ L6 S# O
更多网页制作信息请查看: 网页制作

回复|共 9 个

buingeEvineus 发表于 2016-3-18 11:01:25|INNA | 查看全部
哎 我我我怎么办啊??
tohme 发表于 2016-3-18 11:01:26|巴西 | 查看全部
楼上的话等于没说~~~
wwzcdenleclv 发表于 2016-3-18 11:02:19|IANA | 查看全部
系统居然怀疑我灌水,我身边又没有水龙头。哦…明白了,身上有一个……
wwzcdenleclv 发表于 2016-3-18 11:02:23|英国 | 查看全部
您知道这个论坛的站长是谁吗?偷偷的告诉你他叫叶学得  好厉害的样子
bqtklouu 发表于 2016-3-21 19:06:27|法国 | 查看全部
本人是文盲,以上内容文字均不认识,也看不懂是什么意思.
wwzcdenleclv 发表于 2016-3-21 19:06:52|中国 | 查看全部
看你快沉底了~~~~~~
effoggikeftor 发表于 2016-3-21 19:06:52|广东 | 查看全部
真是天底下好事多多
tohme 发表于 2016-3-21 19:07:05|日本 | 查看全部
宁愿选择放弃,不要放弃选择。
Mqokjdvq 发表于 2016-3-21 19:07:08|Reserved | 查看全部
您知道这个论坛的站长是谁吗?偷偷的告诉你他叫叶学得  好厉害的样子

回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

得知互动是一个融创意、设计、开发、营销、生活、互联网于一体的专业交流分享平台。
Copyright © 2026 站长技术交流论坛|互联网技术交流平台|Ai技术交流平台 版权所有 All Rights Reserved. Powered by Discuz! X5.0 鄂ICP备15006301号-5|鄂公网安备 42018502006730号
关灯 在本版发帖 扫一扫添加QQ客服 返回顶部
快速回复 返回顶部 返回列表