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 相关文章推荐
让广告代码不再影响你的网页加载速度
Jul 07 Javascript
textarea的value是html文件源代码,存成html文件的代码
Apr 20 Javascript
js中substring和substr的详细介绍与用法
Aug 29 Javascript
JS+flash实现chrome和ie浏览器下同时可以复制粘贴
Sep 22 Javascript
node.js实现逐行读取文件内容的代码
Jun 27 Javascript
js实现ArrayList功能附实例代码
Oct 29 Javascript
js+jquery常用知识点汇总
Mar 03 Javascript
浅谈setTimeout 与 setInterval
Jun 23 Javascript
开源免费天气预报接口API及全国所有地区代码(国家气象局提供)
Dec 26 Javascript
浅谈angularjs $http提交数据探索
Jan 20 Javascript
微信小程序点餐系统开发常见问题汇总
Aug 06 Javascript
详解javascript void(0)
Jul 13 Javascript
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
PHP4在WinXP下IIS和Apache2服务器上的安装实例
2006/10/09 PHP
phpMyadmin 用户权限中英对照
2010/04/02 PHP
关于PHP中字符串与多进制转换函数的实例代码
2016/11/03 PHP
PHP使用Redis长连接的方法详解
2018/02/12 PHP
Yii2.0建立公共方法简单示例
2019/01/29 PHP
基于PHP+mysql实现新闻发布系统的开发
2020/08/06 PHP
将光标定位于输入框最右侧实现代码
2012/12/04 Javascript
在Ubuntu上安装最新版本的Node.js
2014/07/14 Javascript
浅谈JavaScript正则表达式分组匹配
2015/04/10 Javascript
微信小程序开发之实现选项卡(窗口顶部TabBar)页面切换
2016/11/25 Javascript
ES6字符串模板,剩余参数,默认参数功能与用法示例
2017/04/06 Javascript
js+html5实现页面可刷新的倒计时效果
2017/07/15 Javascript
BootStrap点击保存后实现模态框自动关闭的思路(模态框)
2017/09/26 Javascript
Angular(5.2-&gt;6.1)升级小结
2018/12/27 Javascript
JS基于开关思想实现的数组去重功能【案例】
2019/02/18 Javascript
JS监听组合按键思路及实现过程
2020/04/17 Javascript
Python functools模块学习总结
2015/05/09 Python
Python中利用Scipy包的SIFT方法进行图片识别的实例教程
2016/06/03 Python
python 循环while和for in简单实例
2016/08/16 Python
python使用正则表达式匹配字符串开头并打印示例
2017/01/11 Python
Python爬取网易云音乐热门评论
2017/03/31 Python
通过python顺序修改文件名字的方法
2018/07/11 Python
python使用正则筛选信用卡
2019/01/27 Python
解决Django加载静态资源失败的问题
2019/07/28 Python
在Python中预先初始化列表内容和长度的实现
2019/11/28 Python
pytorch 归一化与反归一化实例
2019/12/31 Python
tensorflow 获取checkpoint中的变量列表实例
2020/02/11 Python
Stuart Weitzman欧盟:美国奢华鞋履品牌
2017/05/24 全球购物
思想品德自我鉴定
2013/10/12 职场文书
劳资人员岗位职责
2013/12/19 职场文书
讲文明树新风演讲稿
2014/05/12 职场文书
综合管理员岗位职责
2015/02/11 职场文书
幽默导游词开场白
2015/05/29 职场文书
创业计划书之香辣虾火锅
2019/09/23 职场文书
详解Django中 render() 函数的使用方法
2021/04/22 Python
浅谈react useEffect闭包的坑
2021/06/08 Javascript