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


Posted in Javascript onJune 20, 2012

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属性指向父节点

节点关系如下:

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

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));
Javascript 相关文章推荐
中文输入法不触发onkeyup事件的解决办法
Jul 09 Javascript
JavaScript实现标题栏文字轮播效果代码
Oct 24 Javascript
javascript合并表格单元格实例代码
Jan 03 Javascript
jQuery获取父元素及父节点的方法小结
Apr 14 Javascript
js简单倒计时实现代码
Apr 30 Javascript
AngularJS的ng-repeat指令与scope继承关系实例详解
Jan 21 Javascript
npm scripts 使用指南详解
Oct 08 Javascript
关于自定义Egg.js的请求级别日志详解
Dec 12 Javascript
JavaScript类型相关的常用操作总结
Feb 14 Javascript
[原创]微信小程序获取网络类型的方法示例
Mar 01 Javascript
详解vue开发中调用微信jssdk的问题
Apr 16 Javascript
一定要知道的 25 个 Vue 技巧
Nov 02 Vue.js
javascript学习笔记(十七) 检测浏览器插件代码
Jun 20 #Javascript
javascript学习笔记(十六) 系统对话框(alert、confirm、prompt)
Jun 20 #Javascript
javascript学习笔记(十五) js间歇调用和超时调用
Jun 20 #Javascript
javascript学习笔记(十四) window对象使用介绍
Jun 20 #Javascript
javascript学习笔记(十三) js闭包介绍(转)
Jun 20 #Javascript
javascript学习笔记(十二) RegExp类型介绍
Jun 20 #Javascript
javascript学习笔记(十一) 正则表达式介绍
Jun 20 #Javascript
You might like
php中将汉字转换成拼音的函数代码
2012/09/08 PHP
php获取网页标题和内容函数(不包含html标签)
2014/02/03 PHP
PHP return语句另类用法不止是在函数中
2014/09/17 PHP
php中switch语句用法详解
2015/08/17 PHP
php封装json通信接口详解及实例
2017/03/07 PHP
PHP对象相关知识总结
2017/04/09 PHP
PHP实现的回溯算法示例
2017/08/15 PHP
jquery自动完成插件(autocomplete)应用之PHP版
2009/12/15 Javascript
javascript自定义startWith()和endWith()的两种方法
2013/11/11 Javascript
js基于面向对象实现网页TAB选项卡菜单效果代码
2015/09/09 Javascript
BootStrap入门教程(一)之可视化布局
2016/09/19 Javascript
vue+vuex+axios+echarts画一个动态更新的中国地图的方法
2017/12/19 Javascript
vue项目常用组件和框架结构介绍
2017/12/24 Javascript
关于vue面试题汇总
2018/03/20 Javascript
解决vuejs项目里css引用背景图片不能显示的问题
2018/09/13 Javascript
js实现微信聊天界面
2020/08/09 Javascript
基于JavaScript实现轮播图效果
2021/01/02 Javascript
JS数组索引检测中的数据类型问题详解
2021/01/11 Javascript
Django的数据模型访问多对多键值的方法
2015/07/21 Python
python实现给微信公众号发送消息的方法
2017/06/30 Python
python的Crypto模块实现AES加密实例代码
2018/01/22 Python
Python读写及备份oracle数据库操作示例
2018/05/17 Python
Html5移动端获奖无缝滚动动画实现示例
2018/06/25 HTML / CSS
韩国女装NO.1网店:STYLENANDA
2016/09/16 全球购物
JOSEPH官网:英国奢侈时尚品牌
2018/01/31 全球购物
欧洲品牌瓷器餐具网上商店:Porzellantreff.de
2018/04/04 全球购物
巴西宠物商店:Cobasi
2019/04/19 全球购物
乌克兰移动电子产品和相关配件的在线商店:iTMag
2020/03/16 全球购物
数据员岗位职责
2013/11/19 职场文书
回门宴父母答谢词
2014/01/26 职场文书
地理信息科学专业推荐信
2014/09/08 职场文书
开展党的群众路线教育实践活动领导班子对照检查材料
2014/09/25 职场文书
2014年公务员转正工作总结
2014/11/07 职场文书
三严三实·严以律己心得体会
2016/01/13 职场文书
青岛市的收音机研制与生产
2022/04/07 无线电
Windows server 2022创建创建林、域树、子域的步骤
2022/06/25 Servers