日期:2014-05-17 浏览次数:20668 次
一直觉得自己CSS很搓很搓很搓~~~, 入职后决心要加强,以前学CSS都是看比较实践的书籍,如《精通CSS》这些,大多是技巧,靠记忆~~ 发现这样学来实在是根基不牢,永远都要跟着别人后头走。 个人觉得要在某个领域中强大,基础原理是必不可少的,于是有了本人第一篇CSS学习的文章,文章主要是根据《CSS权威指南》来对自己的一些不牢靠的知识进行记录巩固,发现对这本书真是相见恨晚,以前学CSS太浮躁了,地基没打好唉~~废话不多说了,进入正题吧~
在选择器上,主要是一些特殊性和层叠顺序规则需要熟悉。
选择器的特殊性由选择器本身的组件确定。特殊性值表述为4个部分,如:0,0,0,0。一个选择器的具体特殊性如下确定:
一般第一个0是为内联样式保留的。
好吧,先来个例子: .test p span{color:red}; 特殊行为: 0, 1, 2, 0。
这次终于好不容易发挥了我一次研究生的钻研精神,我就想了,这底层估摸是按位来实现的吧?这样就只需1个数字就可以表示了。
有了猜测就要去论证,如何论证? 发挥我无耻的结论导向证明的精神,假设浏览器用1个数字按位表示特殊性,那么每一类别的特殊性肯定都是有上限的,正常情况下应该不会太大,于是有了下面的代码来证明:
基本思路:
给一个id为test的div元素添加样式规则,同时给这个元素添加一定数量的class,再将这些class结合给出另一个规则,如果到达一定数量的class规则覆盖了id规则,那么就证实了我的猜想。
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>Selector Demo</title> <style> #test { color: red; } </style> </head> <body> <div id="test"> 这是一个div,id为test </div> 类添加次数: <input type="text" id="count" /> <input type="button" id="add" value="添加" /> <script> document.getElementById('add').onclick = function() { var t = document.getElementById('test'); var count = Number(document.getElementById('count').value); var cls = ''; var css = ''; //加它个count个类,同时拼接CSS字符串 for (var i = 0; i < count; ++i) { cls += 't' + i + ' '; css += '.t' + i; } css += '{color: blue;}' t.className = cls; //插入规则 loadStyleString(css); }; //插入一条css新规则 var loadStyleString = function(css) { var style = document.createElement('style'); style.type = "text/css"; try { style.appendChild(document.createTextNode(css)); } catch(e) {//IE style.styleSheet.cssText = css; } document.getElementsByTagName('head')[0].appendChild(style); } </script> </body> </html>
在输入框中输入要添加的类次数,JS代码会按照次数给div元素添加对应次数的类,同时会插入一条对应的规则,在代码中,id规则为#test{color:red},
而类规则为{color:blue},所以如果结论正确,那么div的字体颜色会变为蓝色。
通过本屌丝推测性的不懈努力的测试,发现255是个分水岭,超过255次时,也就是2的8次方,二进制11111111,在chrome下div的文字颜色变成了蓝色,
也就是添加的类为256次时,特殊性变成了1,0,0,