常见的原始JS选择器使用方法总结
2014-04-09 00:00
671 查看
常见的getElementById,getElementsByName,getElementsByTagName。但外国人不满意这些API,于是搞出了getElementsByClassName,后来一点点又出现了jQuery选择器,这里只说原始js选择。
1.getElementById
这是最常用的选择器,通过id来定位:
例:
var test=document.getElementById("test").value;//获取文档中id为test的元素的值,并赋值给test变脸
2.getElementsByName
例:
var test=document.getElementByName("test");//获取文档中name为test的元素的节点,并赋值给test变量,此时test变量是一个数组
3.getElementsByTagName
例:
var test=document.getElementsByTagName("test");//获取文档中class为test的元素的节点,并赋值给test,此时test变量是一个数组 ,这个选择器在IE5,6,7,8中无法使用
4.getElementsByClassName
这个选择器在js的API中是找不到的,想要使用必须自己定义方法,通常的原理为先使用getElementsByTagName("*")取出文档中所有元素,然后进行遍历,使用正则表达式找出匹配的元素放入一个数组返回。网上有很多程序员实现了这个选择器,下面举两例:
(1)The Ultimate getElementsByClassName方案,作者为Robert Nyman,05年实现,可见老外许多东西在很早以前就走得很远了。
(2)由Dustin Diaz(《JavaScript Design Patterns》的作者)提供,但兼容性不如上面的,不支持IE5。
--------------------------------------------------------------------------------------------------------------------------------------------------------
注:this可以表示当前元素的节点。
--------------------------------------------------------------------------------------------------------------------------------------------------------
下面是配合事件等知识点的一些常用的使用方法:
1.getElementById
这是最常用的选择器,通过id来定位:
例:
var test=document.getElementById("test").value;//获取文档中id为test的元素的值,并赋值给test变脸
2.getElementsByName
例:
var test=document.getElementByName("test");//获取文档中name为test的元素的节点,并赋值给test变量,此时test变量是一个数组
3.getElementsByTagName
例:
var test=document.getElementsByTagName("test");//获取文档中class为test的元素的节点,并赋值给test,此时test变量是一个数组 ,这个选择器在IE5,6,7,8中无法使用
4.getElementsByClassName
这个选择器在js的API中是找不到的,想要使用必须自己定义方法,通常的原理为先使用getElementsByTagName("*")取出文档中所有元素,然后进行遍历,使用正则表达式找出匹配的元素放入一个数组返回。网上有很多程序员实现了这个选择器,下面举两例:
(1)The Ultimate getElementsByClassName方案,作者为Robert Nyman,05年实现,可见老外许多东西在很早以前就走得很远了。
//三个参数都是必需的,查找一网页中5007个类名为“cell”的元素,IE8历时1828 ~ 1844毫秒, //IE6为4610 ~ 6109毫秒,FF3.5为46 ~ 48毫秒,opera10为31 ~ 32毫秒,Chrome为23~ 26毫秒, //safari4为19 ~ 20毫秒 function getElementsByClassName(oElm, strTagName, strClassName){ var arrElements = (strTagName == "*" && oElm.all)? oElm.all : oElm.getElementsByTagName(strTagName); var arrReturnElements = new Array(); strClassName = strClassName.replace(/\-/g, "\\-"); var oRegExp = new RegExp("(^|\\s)" + strClassName + "(\\s|$)"); var oElement; for(var i=0; i < arrElements.length; i++){ oElement = arrElements[i]; if(oRegExp.test(oElement.className)){ arrReturnElements.push(oElement); } } return (arrReturnElements) }
(2)由Dustin Diaz(《JavaScript Design Patterns》的作者)提供,但兼容性不如上面的,不支持IE5。
//后两参数是可靠的,查找一网页中5007个类名为“cell”的元素,IE8历时78毫秒,IE6历时125~171毫秒 //FF3.5为42 ~ 48毫秒,opera10为31 毫秒,Chrome为22~ 25毫秒,safari4为18 ~ 19毫秒 var getElementsByClass = function(searchClass,node,tag) { var classElements = new Array(); if ( node == null ) node = document; if ( tag == null ) tag = '*'; var els = node.getElementsByTagName(tag); var elsLen = els.length; var pattern = new RegExp("(^|\\s)"+searchClass+"(\\s|$)"); for (i = 0, j = 0; i < elsLen; i++) { if ( pattern.test(els[i].className) ) { classElements[j] = els[i]; j++; } } return classElements; }
--------------------------------------------------------------------------------------------------------------------------------------------------------
注:this可以表示当前元素的节点。
--------------------------------------------------------------------------------------------------------------------------------------------------------
下面是配合事件等知识点的一些常用的使用方法:
//提交id为test的表单 document.getElementById("test").submit(); //将id为test元素的边框设置为2个像素,实体,红色 document.getElementById("test").style.border="2px solid red"; //鼠标移动或移出id为test的元素,改变其背景色 function test(){ document.getElementById("test").onmouseover=function(){document.getElementById("test2").style.backgroundColor="red"}; document.getElementById("test").onmouseout=function(){document.getElementById("test2").style.backgroundColor="blue"}; } //弹出文档中name为test的元素的个数 function test() { var test=document.getElementsByName("test"); alert(test.length); }
相关文章推荐
- 常见的原始JS选择器使用方法总结
- 常见的原始JS选择器使用方法总结
- 原始JS选择器使用方法总结
- 原始JS选择器使用方法和常用事件手册
- [置顶] ckeditor 的几种使用方法总结(附演示工程文件,并且解决几个常见错误)
- js常见的判断移动端或者pc端或者安卓和苹果浏览器的方法总结
- js 使用方法与函数 总结第1/4页
- ckeditor 的几种使用方法总结(附演示工程文件,并且解决几个常见错误)
- 常见js选择器总结
- Atitit.angular.js 使用最佳实践 原理与常见问题解决与列表显示案例 attilax总结
- stylus使用文档总结:选择器+变量+插值+运算符+混合书写+方法
- js学习笔记(1)之document.write()方法使用总结
- 扫描仪使用过程中常见问题解决方法总结
- 【前端】Require.js使用方法总结
- Atitit.angular.js 使用最佳实践 原理与常见问题解决与列表显示案例 attilax总结
- js自己封装的开发使用工具方法总结
- js中几种方法的使用总结
- Atitit.angular.js 使用最佳实践 原理与常见问题解决与列表显示案例 attilax总结
- 解析使用js判断只能输入数字、字母等验证的方法(总结)
- js创建类的几种常见方法总结