常见的原始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 相关文章推荐
两个SUBMIT按钮,如何区分处理
Aug 22 Javascript
学习并汇集javascript匿名函数
Nov 25 Javascript
修复ie8&amp;chrome下window的resize事件多次执行
Oct 20 Javascript
分页栏的web标准实现
Nov 01 Javascript
利用javascript实现web页面中指定区域打印
Oct 30 Javascript
jquery实现select选中行、列合计示例
Apr 25 Javascript
node.js中的fs.openSync方法使用说明
Dec 17 Javascript
BootStrap glyphicon图标无法显示的解决方法
Sep 06 Javascript
JS查找英文文章中出现频率最高的单词
Mar 20 Javascript
Vue-cli3.X使用px2 rem遇到的问题及解决方法
Aug 08 Javascript
使用node.JS中的url模块解析URL信息
Feb 06 Javascript
JS实现纸牌发牌动画
Jan 19 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/10/09 PHP
phpMyAdmin链接MySql错误 个人解决方案
2009/12/28 PHP
php stream_get_meta_data返回值
2013/09/29 PHP
PHP的Yii框架的基本使用示例
2015/08/21 PHP
使用Zookeeper分布式部署PHP应用程序
2019/03/15 PHP
豆瓣网的jquery代码实例
2008/06/15 Javascript
javascript 解析后的xml对象的读取方法细解
2009/07/25 Javascript
JavaScript高级程序设计 XML、Ajax 学习笔记
2011/09/10 Javascript
Js 时间间隔计算的函数(间隔天数)
2011/11/15 Javascript
JavaScript使用Math.Min返回两个数中较小数的方法
2015/04/06 Javascript
js字符串操作方法实例分析
2015/05/06 Javascript
浅谈setTimeout 与 setInterval
2015/06/23 Javascript
node.js平台下的mysql数据库配置及连接
2017/03/31 Javascript
js排序与重组的实例讲解
2017/08/28 Javascript
vue.js使用v-if实现显示与隐藏功能示例
2018/07/06 Javascript
Echarts动态加载多条折线图的实现代码
2019/05/24 Javascript
JavaScript链式调用原理与实现方法详解
2020/05/16 Javascript
vue3.0 项目搭建和使用流程
2021/03/04 Vue.js
python实现马耳可夫链算法实例分析
2015/05/20 Python
浅谈Django学习migrate和makemigrations的差别
2018/01/18 Python
Tensorflow实现卷积神经网络用于人脸关键点识别
2018/03/05 Python
python遍历文件夹,指定遍历深度与忽略目录的方法
2018/07/11 Python
python处理DICOM并计算三维模型体积
2019/02/26 Python
python数据类型可变不可变知识点总结
2020/03/06 Python
如何使用PyCharm引入需要使用的包的方法
2020/09/22 Python
浅析Python requests 模块
2020/10/09 Python
python openssl模块安装及用法
2020/12/06 Python
在使用非全零作为空指针内部表达的机器上, NULL是如何定义
2014/11/09 面试题
.NET程序员的几道面试题
2012/06/01 面试题
党员群众路线对照检查材料
2014/08/31 职场文书
销售会议开幕词
2015/01/28 职场文书
天气温馨提示语
2015/07/14 职场文书
2015秋季开学典礼演讲稿
2015/07/16 职场文书
通讯稿范文
2015/07/22 职场文书
生产车间管理制度
2015/08/04 职场文书
职工宿舍管理制度
2015/08/05 职场文书