在IE中用javascript配合 使用first-child伪类

  次阅读 作者:智能小宝 来源:互联网 2016-03-25 16:34 我要评论(0)

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

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

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

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

给未支持:first-child的浏览器添加first-child的class

代码如下

复制代码

function addClassName(tag, classname) {

if (!tag.className)

{

tag.className = classname;

}

else {

tag.className += " " + classname;

}

}

function addFirstChild() {

var olitems = document.getElementsByTagName("ol");

var ulitems = document.getElementsByTagName("ul");

for ( var i = 0 ; i < olitems.length ; i++ )

{

addClassName(olitems[i].getElementsByTagName("li")["0"], "first-child");

}

for ( var i = 0 ; i < ulitems.length ; i++ )

{

addClassName(ulitems[i].getElementsByTagName("li")["0"], "first-child");

}

}

if (document.all && !window.opera)

{

window.onload = addFirstChild;

}

body {font: 81.25%/1.7 Sans-Serif;}

li:first-child, li.first-child {color: red;}

给未支持:first-child的浏览器添加first-child的class

请使用IE浏览器,如果您能看到每个列表项的第一个li的颜色是红色,那么证明我们成功地选择了first-child。

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...