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

 更新时间:2012年06月20日 20:20:36   作者:  
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
复制代码 代码如下:

var images = document.getElementsByTagName("img"); //获取页面中的所有<img>元素

alert(images.length); //图像的数量
alert(images[0].src); //第一个图片元素的src
alert(images.item(0).src); //同上

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

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


2.获取元素子节点或元素子节点及其后代节点
复制代码 代码如下:

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

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

<ul id="myList"><li>项目一</li><li>项目二</li><li>项目三</li></ul>  
任何浏览器都认为有3个子节点

获取元素的子节点:
复制代码 代码如下:

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

获取元素的子节点及其后代节点:
复制代码 代码如下:

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

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

节点关系如下:

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

function converToArray (nodes) {
var arrary = null;
try {
array = Array.prototype.slice.call(nodes,0);
}
catch (ex) {
array = new Array();
for (var i=0,len=nodes.length ; i<len ; i++) {
array.push(nodes[i]);
}
}
return array;
}

var div = document.getElementById("side");
alert(converToArray(div.childNodes));

相关文章

  • asm.js使用示例代码

    asm.js使用示例代码

    asm.js是一个底层、格外为 JavaScript 子集优化的编译器。这是 Mozilla 研究项目,类似 Emscripten, Mandreel, 和 LLJS,这个示例让我们简单学习一下asm.js的使用
    2013-11-11
  • 删除Javascript Object中间的key

    删除Javascript Object中间的key

    这篇文章介绍了删除Javascript Object中间的key的方法,然后主要详谈了delete的用法,非常的详尽,给小伙伴们参考下
    2014-11-11
  • Javascript学习笔记7 原型链的原理

    Javascript学习笔记7 原型链的原理

    说到prototype,就不得不先说下new的过程。
    2010-01-01
  • javascript 多浏览器 事件大全

    javascript 多浏览器 事件大全

    javascript 多浏览器 事件大全 ,对于一些事件的使用限制于触发方法可以参考下。
    2010-03-03
  • 详解JavaScript编程中正则表达式的使用

    详解JavaScript编程中正则表达式的使用

    这篇文章主要介绍了详解JavaScript编程中正则表达式的使用,并列出了JS所支持的正则第oxo昂,需要的朋友可以参考下
    2015-10-10
  • 深入分析原生JavaScript事件

    深入分析原生JavaScript事件

    这篇文章主要介绍了原生JavaScript事件,包括DOM0事件模型、DOM2事件模型等的相关知识,需要的朋友可以参考下
    2014-12-12
  • Javascript学习笔记之 函数篇(三) : 闭包和引用

    Javascript学习笔记之 函数篇(三) : 闭包和引用

    本系列好久没更新了,今天重新拿过来,继续前面未完成的事项,本文我们就来谈谈Javascript 中一个最重要的特性--闭包的使用引用。
    2014-11-11
  • JavaScript操作HTML DOM节点的基础教程

    JavaScript操作HTML DOM节点的基础教程

    这篇文章主要介绍了JavaScript操作HTML DOM节点的基础入门教程,包括对节点的创建修改删除等操作,还特别提到了其中appendChild()与insertBefore()插入节点时需注意的问题,需要的朋友可以参考下
    2016-03-03
  • javascript设计模式之对象工厂函数与构造函数详解

    javascript设计模式之对象工厂函数与构造函数详解

    这篇文章主要介绍了javascript设计模式之对象工厂函数与构造函数详解,使用对象字面量,或者向空对象中动态地添加新成员,是最简单易用的对象创建方法,除了这两种常用的对象创建方式,JavaScript还提供了其他方法创建对象,需要的朋友可以参考下
    2015-07-07
  • 浅析JS操作DOM的一些常用方法

    浅析JS操作DOM的一些常用方法

    下面小编就为大家带来一篇JS操作DOM的一些常用方法。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-05-05

最新评论