《JavaScript学习笔记四》:getElementsByTagName的使用以及全选、反选和取消功能实现
2016-05-29 20:39
525 查看
《JavaScript学习笔记四》:getElementsByTagName的使用以及全选、反选和取消功能实现
我们都知道getElementById是通过id来获取对象,但是,当我们的对象许多且这些对象都是相同的时候,如果还使用getElementById来一个一个的来获取对象就比较坑爹了,是吧,因此,就有了getElementsByTagName来通过标签来获取对象数组。例如:var aBtn=document.getElementsByTagName(“input”);就是获取input下的type=”button”的button对象数组。
还是以一个例子来进行说明:
在我们的生活中,许多网页都存在“全选” “反选” “取消”等功能,下面我们就来实现这一功能。
思路比较简单,
实现代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>无标题文档</title> <script> window.onload=function () { //得到所有的button对象 var oDiv=document.getElementById('div1'); var aBtn=oDiv.getElementsByTagName('input'); //得到所有的checkbox对象 oDiv=document.getElementById('div2'); var aCheckBox=oDiv.getElementsByTagName('input'); for(var i=0;i<aBtn.length;i++) { aBtn[i].onclick=function () { if(this.value==="全选") //注意:这里不能写aBtn[i]==="全选" { for(var j=0;j<aCheckBox.length;j++) { aCheckBox[j].checked=true; } } else if(this.value==='取消') { for(var j=0;j<aCheckBox.length;j++) { aCheckBox[j].checked=false; } } if(this.value==='反选') { for(var j=0;j<aCheckBox.length;j++) { if(aCheckBox[j].checked==true) { aCheckBox[j].checked=false; } else { aCheckBox[j].checked=true; } } } }; //注意:这里有一个分号 } }; </script> </head> <body> <div id="div1"> <input type="button" value="全选" /> <input type="button" value="反选" /> <input type="button" value="取消" /> </div> <div id="div2"> <input type="checkbox" checked="true"/><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> </div> </body> </html>
在上面的代码实现中,遇到了一个问题,刚开始我在每个按钮的onclick事件中使用了aBtn[i].value====”全选”这样的语句,发现这样是不行的,错误的,只能使用this.value===”全选”,这就涉及到this关键字的使用了,这个以后再说
在debug的过程中,由于一致没有找出这个错误,因此,就写了下面这个版本:每个按钮的onclick都对应一个function。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>无标题文档</title> <script> window.onload=function () { var oBtn1=document.getElementById('btn1'); var oBtn2=document.getElementById('btn2'); var oBtn3=document.getElementById('btn3'); var oDiv=document.getElementById('div2'); var aCheckBox=oDiv.getElementsByTagName('input'); var len=aCheckBox.length; //全选 oBtn1.onclick=function () { for(var i=0;i<len;i++) { aCheckBox[i].checked=true; } }; //反选 oBtn2.onclick=function () { for(var i=0;i<len;i++) { if(aCheckBox[i].checked==true) { aCheckBox[i].checked=false; } else { aCheckBox[i].checked=true; } } }; //取消 oBtn3.onclick=function () { for(var i=0;i<len;i++) { aCheckBox[i].checked=false; } }; }; </script> </head> <body> <input id="btn1" type="button" value="全选" /> <input id="btn2" type="button" value="反选" /> <input id="btn3" type="button" value="取消" /> <div id="div2"> <input type="checkbox" checked="true"/><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> <input type="checkbox" /><br /> </div> </body> </html>
小结
例子虽然简单,但遇到的bug还是挺难让人发现的也,可能还是自己对js了解的不够吧相关文章推荐
- serservlet 一生
- JSTL不能使用的问题
- 吃透Javascript数组操作的正确姿势—再读《Js高程》
- d3.js学习笔记(2)—— Transition
- IE11 Windows7下F12 DOC资源管理器不能用Exception in window.onload: Error: An error has ocurredJSPlugin.3005
- javascript加载xml文件,兼容Chrome
- 从js向Action传中文参数出现乱码问题的解决方法
- servlet与jsp核心编程(持续更新)
- ES5, ES6, ES2016, ES.Next: JavaScript 的版本是怎么回事?「译」
- 用原生JavaScript实现图片瀑布流的浏览效果
- javascript中的立即执行函数
- 从零开始学_JavaScript_系列(22)——dojo(9)(表单、JsonRest的post方法,widget的使用思路)
- javascript+Java 实现MD5加密登录密码
- js基础-input对象,select对象,实例:二级联动菜单
- js处理一个div里面多个点击事件时出现的事件冲突 重复的解决方法 事件冒泡
- JavaScript写一个距离高考还有多少天的案例
- javascript笔试题(4) js模板
- 使用jsoup采集网页实例
- JavaScript(一)基本语法
- 浅析js模板引擎