真・懒

订阅 Twitter GitHub 联系

在 IE 中使用 first-child

使用 web standards 做网页,经常需要定义某个父元素下的第一个子(child)元素或最后一个元素,以便将其与其他元素区分开来,有利于实现某些特殊需求。最浅显的例子是,导航项目间的竖线,我们往往通过 border 或者 background 来实现。特殊需求是,第一项左边无竖线或最后一项右边无竖线。

那么区分第一项好呢,还是最后一项好?答案是明显的,逼不得已,不要用区别最后一项。按照一般的编程方法,控制第一项要比控制最后一项容易得多

区分第一项的还有一个好处是,CSS 有一个 :first-child 的伪元素(pseudo element)可以让我们轻而易举的选择第一个子元素。

遗憾的是,当前全球占有率最高的浏览器,IE6,并不支持这个伪元素。我们可以手工给第一个元素加上 class 然后再定义它。但这不是一个万无一失的办法,尤其对于页面规模达到一定数量大型网站,很容易挂一漏万。那么,让 JavaScript 来帮我们完成这件工作如何?

查看 http://realazy.com/lab/first-child-js/

在 IE 中,为每个属于 first-child 的 li 加上 first-child 的 class,则 CSS 则可以这样书写了::first-child, .first-child { some rules here...}(有没有发现这样写很帅,一个是冒号,两点;一个是点号,一点 :)),十分便于维护和管理。

p.s.希望哪位高手能够写出通用的 first-child 来,我这里的例子只针对 li,能力有限 XD ...