javascript学习笔记(十八) 获得页面中的元素

1.获取元素
getElementById()方法,通过元素的id获取元素,接受一个参数即要获取元素的id,如果不存在这个id返回 null
注意不要让表单元素的name和别的元素的id相同,IE8以下的IE浏览器用这个方法通过元素的name属性可以获得该元素
以下面元素为例

<div id ="myDiv">这里是id为“myDiv”的div内容</div>
var document.getElementById("myDiv");        //"myDiv"区分大小写,取得<div>元素的引用

getElementsByTagName()方法,通过元素的标签名获得元素,接受一个参数即要获取元素的标签名,返回包含0个或多个的NodeList

1 var images = document.getElementsByTagName("img");        //获取页面中的所有<img>元素
2 
3 alert(images.length);         //图像的数量
4 alert(images[0].src);         //第一个图片元素的src
5 alert(images.item(0).src);    //同上

getElementsByName()方法,通过元素的name属性获得元素,接受一个参数即要获取元素的name属性,常用来获取单选按钮

1 <ul>
2     <li><input type="radio" name="color" value="red" id="colorRed"><label for="colorRed"></label></li>
3     <li><input type="radio" name="color" value="green" id="colorGreen"><label for="colorGreen"></label></li>
4     <li><input type="radio" name="color" value="blue" id="colorBlue"><label for="colorBlue"></label></li>
5 </ul>
var radios = document.getElementsByName("color");    //获取name="color"的所有单选按钮

 

2.获取元素子节点或元素子节点及其后代节点

1 <ul id="myList">
2     <li>项目一</li>
3     <li>项目二</li>
4     <li>项目三</li>
5 </ul>

注意:IE认为<ul>元素有3个子节点,分别是3个元素,其他浏览器会认为有7个子节点,包括3个元素和4个文本节点,如果<ul>在一行中:

<ul id="myList"><li>项目一</li><li>项目二</li><li>项目三</li></ul>  

任何浏览器都认为有3个子节点

获取元素的子节点:

1 var ul = document.getElementById("myList");
2 for (var i=0,len = ul.childNodes.length ; i < len ; i++ ) {
3     if ( ul.childNodes.length[i].nodeType == 1) {            //nodeType == 1 说明节点是元素节点,而不是文本节点
4                 //执行某些操作
5     }
6 }

获取元素的子节点及其后代节点:

1 var ul = document.getElementById("myList");
2 var items = ul.getElementsByTagName("li");        //li里的li也会被取得

 

3通过节点的属性查找其它节点
nextSibling属性指向当前节点的下一个兄弟节点
previousSibling属性指向当前节点的上一个兄弟节点
firstChild属性指向第一个子节点,lastChild指向最后一个子节点
childNodes保存着所有子节点(其实是NodeList对象),可以通过方括号的方法访问如 someNode.childNodes[0] 访问第一个子节点
parentNode属性指向父节点

节点关系如下:

NodeList是个数组对象,我们可以把它转换为数组,函数如下

 1 function converToArray (nodes) {
 2         var arrary = null;
 3         try {
 4             array = Array.prototype.slice.call(nodes,0);
 5         }
 6         catch (ex)    {
 7             array = new Array();
 8             for (var i=0,len=nodes.length ; i<len ; i++)    {
 9                 array.push(nodes[i]);
10             }
11         }
12         return array;
13     }
14 
15     var div = document.getElementById("side");
16     alert(converToArray(div.childNodes));

转载于:https://www.cnblogs.com/jianxinrl/archive/2012/06/01/2531145.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值