hi,欢迎访问本站!
当前位置: 首页学习笔记正文

JavaScript中常见获取元素的方法汇总

用户投稿 学习笔记 3658阅读

网页的制作离不开JavaScript(JS)今天就说说那些关于JavaScript(JS)操作DOM节点的一些属性,做个记录,以备后续查找!

getattribute()

DOM提供了一个名为getElementById的方法,这个方法将返回一个与之对应id属性的节点对象。使用的时候请注意区分大小写。

getattribute(),getattribute(),getElementsByTagName(),getElementsByClassName(),HTML DOM getAttribute() 方法,setAttribute(),JS操作DOM的属性

它是document对象特有的函数,只能通过其来调用该方法。

使用的方法如下:

document.getElementById('demo') //demo是元素对应的ID

此方法兼容IE6+以上的所有浏览器,可以放心使用

getElementsByTagName()

该方法返回一个对象数组(准确的说是HTMLCollection集合,它不是真正意义上的数组),每个对象分别对应着文档里有着给定标签的一个元素。类似于getElementById,同样,该方法只提供一个参数,它的参数是指定标签的名字.

代码如下:

document.getElementsByTagname('li')  //li是标签的名字

需要注意的是,该方法除了能被document对象调用之外,还可以被普通的元素调用。

示例如下:

var demo = document.getElementById('demo');var lis = demo.getElementsByTagname('li');

    

此方法兼容IE6+以上的所有浏览器,可以放心使用

getElementsByClassName()

除了通过指定标签获取元素外,DOM还提供了getElementsByClassName方法来获取指定class名的元素。不过由于该方法比较新,较老的浏览器还不支持,比如IE6。不过我们可以通过hack方式来弥补老浏览器缺陷。

document.getElementsByClassName('demo')    //demo为元素指定的class名

和getElementsByTagname一样, 该方法除了能被document对象调用之外,还可以被普通的元素调用。

对于比较老的浏览器,比如IE6、7我们可以通过下面的hack方式来实现:

function getElementsByClassName(node,classname){        if(node.getElementsByClassName) {            return node.getElementsByClassName(classname);        }else {            var results = [];            var elems = node.getElementsByTagName("*");            for(var i = 0; i < elems.length; i++){                if(elems[i].className.indexOf(classname) != -1){                    results[results.length] = elems[i];                }            }            return results;        }    }

getAttribute()

getAttribute()方法是一个函数。它只有一个参数——你打算查询的属性的名字:

getAttribute()方法不能通过document对象调用,这与我们此前介绍过的其他方法不同。我们只能通过一个元素节点对象调用它。

你可以把它与getElementsByTagName()方法结合起来,去查询每个<p>元素的title属性

代码如下:

var text=document.getElementsByTagName("p")for (var i=0;i<text.length;i++){alert(text[i].getAttribute("title"));}

setAttribute()

setAttribute()函数可以设置对象的属性,如果不存在此属性,则会创建此属性。

代码:

var ts=document.getElementsByTagName("li");for (var i=0; i<ts.length;i++){var text=ts[i].getAttribute("title");alert(ts[i].getAttribute("title"))if(text){ts[i].setAttribute("title","我会成功!")alert(ts[i].getAttribute("title"))}}

上面的示例代码,来自网络,有什么不对的,大家可以在下方留言哦!

标签:
声明:无特别说明,转载请标明本文来源!
发布评论
正文 取消