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 相关文章推荐
JavaScript Math.ceil() 函数使用介绍
Dec 11 Javascript
用JavaScript实现对话框的教程
Jun 04 Javascript
JavaScript简单下拉菜单实例代码
Sep 07 Javascript
JavaScript实现格式化字符串函数String.format
Dec 16 Javascript
详解微信小程序——自定义圆形进度条
Dec 29 Javascript
js判断是否是手机页面
Mar 17 Javascript
js+html获取系统当前时间
Nov 10 Javascript
使用node打造自己的命令行工具方法教程
Mar 26 Javascript
微信小程序实现slideUp、slideDown滑动效果及点击空白隐藏功能示例
Dec 11 Javascript
ionic3双击返回退出应用的方法
Sep 17 Javascript
vue-router重写push方法,解决相同路径跳转报错问题
Aug 07 Javascript
node.js通过Sequelize 连接MySQL的方法
Dec 28 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
浅谈php优化需要注意的地方
2014/11/27 PHP
Yii2框架引用bootstrap中日期插件yii2-date-picker的方法
2016/01/09 PHP
PHP操作XML中XPath的应用示例
2019/07/04 PHP
JQuery 常用方法和事件详细介绍
2013/04/18 Javascript
jquery获取tr并更改tr内容示例代码
2014/02/13 Javascript
jquery搜索框效果实现方法
2015/01/16 Javascript
nodejs实现获取当前url地址及url各种参数值
2015/06/25 NodeJs
jQuery焦点图插件SaySlide
2015/12/21 Javascript
通过隐藏iframe实现无刷新上传文件操作
2016/03/16 Javascript
window.onload绑定多个事件的两种解决方案
2016/05/15 Javascript
jQuery过滤选择器用法示例
2016/09/12 Javascript
微信小程序Server端环境配置详解(SSL, Nginx HTTPS,TLS 1.2 升级)
2017/01/12 Javascript
vue+axios实现登录拦截的实例代码
2017/05/22 Javascript
Vue.js 中的 $watch使用方法
2017/05/25 Javascript
vue.js 获取当前自定义属性值
2017/06/01 Javascript
史上最全JavaScript常用的简写技巧(推荐)
2017/08/17 Javascript
详解AngularJS跨页面传值(ui-router)
2017/08/23 Javascript
vue环境搭建简单教程
2017/11/07 Javascript
MVVM框架下实现分页功能示例
2018/06/14 Javascript
vue实现todolist基本功能以及数据存储功能实例详解
2019/04/11 Javascript
基于JS实现web端录音与播放功能
2019/04/17 Javascript
Vue路由前后端设计总结
2019/08/06 Javascript
Python 字符串操作方法大全
2014/03/11 Python
Python双精度浮点数运算并分行显示操作示例
2017/07/21 Python
python逆向入门教程
2018/01/15 Python
Python实现的三层BP神经网络算法示例
2018/02/07 Python
Python 实现一行输入多个值的方法
2018/04/21 Python
解决pycharm运行时interpreter为空的问题
2018/10/29 Python
Django中celery执行任务结果的保存方法
2019/07/12 Python
Django中reverse反转并且传递参数的方法
2019/08/06 Python
python PIL和CV对 图片的读取,显示,裁剪,保存实现方法
2019/08/07 Python
CSS3选择器新增问题的实现
2021/01/21 HTML / CSS
英国鞋类及配饰零售商:Kurt Geiger
2017/02/04 全球购物
商务主管岗位职责
2013/12/08 职场文书
中式餐厅创业计划书范文
2014/01/23 职场文书
小学教师师德师风自我评价
2015/03/04 职场文书