常见的原始JS选择器使用方法总结


Posted in Javascript onApril 09, 2014

常见的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年实现,可见老外许多东西在很早以前就走得很远了。

//三个参数都是必需的,查找一网页中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); 

}
Javascript 相关文章推荐
JS的IE和Firefox兼容性集锦
Dec 11 Javascript
DOM 中的事件处理介绍
Jan 18 Javascript
Jquery对数组的操作技巧整理
Mar 25 Javascript
基于BootStarp的Dailog
Apr 28 Javascript
实例讲解jQuery中对事件的命名空间的运用
May 24 Javascript
webpack入门+react环境配置
Feb 08 Javascript
利用Javascript裁剪图片并存储的简单实现
Mar 13 Javascript
JavaScript之json_动力节点Java学院整理
Jun 29 Javascript
JavaScript利用fetch实现异步请求的方法实例
Jul 26 Javascript
利用angular、react和vue实现相同的面试题组件
Feb 19 Javascript
Vue项目pdf(base64)转图片遇到的问题及解决方法
Oct 19 Javascript
微信小程序 textarea 层级过高问题简单解决方案
Oct 14 Javascript
jquery查找父元素、子元素(个人经验总结)
Apr 09 #Javascript
js控制iframe的高度/宽度让其自适应内容
Apr 09 #Javascript
JS、DOM和JQuery之间的关系示例分析
Apr 09 #Javascript
jQuery遍历Table应用示例
Apr 09 #Javascript
通过url查找a元素并点击
Apr 09 #Javascript
js数组方法扩展实现数组统计函数
Apr 09 #Javascript
jquery实现pager控件示例
Apr 09 #Javascript
You might like
PHP中,文件上传
2006/12/06 PHP
PHP伪造来源HTTP_REFERER的方法实例详解
2015/07/06 PHP
关于PHP5.6+版本“No input file specified”问题的解决
2019/12/11 PHP
不使用浏览器运行javascript代码的方法
2013/07/24 Javascript
JS 屏蔽键盘不可用与鼠标右键不可用的方法
2013/11/18 Javascript
jQuery如何取id有.的值一般的方法是取不到的
2014/04/18 Javascript
js中将String转换为number以便比较
2014/07/08 Javascript
JQuery中使用ajax传输超大数据的解决方法
2014/07/14 Javascript
js实现动画特效的文字链接鼠标悬停提示的方法
2015/03/02 Javascript
jQuery设置指定网页元素宽度和高度的方法
2015/03/25 Javascript
JS基于FileSystemObject创建一个指定路径的TXT文本文件
2015/08/05 Javascript
js控制元素显示在屏幕固定位置及监听屏幕高度变化的方法
2015/08/11 Javascript
js 实现数值的千分位及保存小数方法(推荐)
2016/08/01 Javascript
JQuery控制DIV的选取实现方法
2016/09/18 Javascript
JavaScript模仿Pinterest实现图片预加载功能
2016/10/25 Javascript
详解用原生JavaScript实现jQuery的某些简单功能
2016/12/19 Javascript
jQuery编写textarea输入字数限制代码
2017/03/23 jQuery
浅谈js基础数据类型和引用类型,深浅拷贝问题,以及内存分配问题
2017/09/02 Javascript
vue按需引入element Transfer 穿梭框
2017/09/30 Javascript
vue :src 文件路径错误问题的解决方法
2018/05/15 Javascript
通过jquery的ajax请求本地的json文件方法
2018/08/08 jQuery
JavaScript键盘事件常见用法实例分析
2019/01/03 Javascript
vue 实现一个简单的全局调用弹窗案例
2020/09/10 Javascript
python使用自定义user-agent抓取网页的方法
2015/04/15 Python
Python2.x版本中cmp()方法的使用教程
2015/05/14 Python
python实现贪吃蛇游戏
2020/03/21 Python
用django-allauth实现第三方登录的示例代码
2019/06/24 Python
HTML5离线缓存Manifest是什么
2016/03/09 HTML / CSS
html5 Canvas画图教程(6)—canvas里画曲线之arcTo方法
2013/01/09 HTML / CSS
有模特经验的简历自我评价
2013/09/19 职场文书
高中语文教学反思
2014/01/16 职场文书
高中军训感想800字
2014/02/23 职场文书
学习演讲稿范文
2014/05/10 职场文书
优秀团员事迹材料
2014/12/25 职场文书
《乘法分配律》教学反思
2016/02/24 职场文书
PHP中->和=>的意思
2021/03/31 PHP