常见的原始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 相关文章推荐
Jquery调用webService远程访问出错的解决方法
May 21 Javascript
基于jquery的文本框与autocomplete结合使用(asp.net+json)
May 30 Javascript
详解JavaScript的Date对象(制作简易钟表)
Apr 07 Javascript
详解JavaScript的另类写法
Apr 11 Javascript
JavaScript 数组中最大最小值
Jun 05 Javascript
Vue.js 和 MVVM 的注意事项
Nov 07 Javascript
js格式化时间的简单实例
Nov 27 Javascript
浅析上传头像示例及其注意事项
Dec 14 Javascript
详解vue-cli官方脚手架配置
Jul 20 Javascript
微信小程序 Storage更新详解
Jul 16 Javascript
vue-loader中引入模板预处理器的实现
Sep 04 Javascript
使用kbone解决Vue项目同时支持小程序问题
Nov 08 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
输出控制类
2006/10/09 PHP
从网上搜到的phpwind 0day的代码
2006/12/07 PHP
windows下配置php5.5开发环境及开发扩展
2014/12/25 PHP
php 截取utf-8格式的字符串实例代码
2016/10/30 PHP
PHP开启目录引索+fancyindex漂亮目录浏览带搜索功能
2019/09/23 PHP
PHP执行系统命令函数实例讲解
2021/03/03 PHP
教您去掉ie网页加载进度条的方法
2010/12/09 Javascript
jQuery大于号(&gt;)选择器的作用解释
2015/01/13 Javascript
JavaScript简单表格编辑功能实现方法
2015/04/16 Javascript
jQuery中Ajax全局事件引用方式及各个事件(全局/局部)执行顺序
2016/06/02 Javascript
浅析JavaScript中命名空间namespace模式
2016/06/22 Javascript
canvas学习之API整理笔记(一)
2016/12/29 Javascript
nodejs中全局变量的实例解析
2017/03/07 NodeJs
js获取元素的偏移量offset简单方法(必看)
2017/07/05 Javascript
详解基于webpack2.x的vue2.x的多页面站点
2017/08/21 Javascript
详解Vue中一种简易路由传参办法
2017/09/15 Javascript
JS二分查找算法详解
2017/11/01 Javascript
JavaScript设计模式之观察者模式实例详解
2019/01/16 Javascript
如何检查一个对象是否为空
2019/04/11 Javascript
这样回答继承可能面试官更满意
2019/12/10 Javascript
javascript使用正则表达式实现注册登入校验
2020/09/23 Javascript
python批量修改文件名的实现代码
2014/09/01 Python
python日志记录模块实例及改进
2017/02/12 Python
使用python画个小猪佩奇的示例代码
2018/06/06 Python
详解python中Numpy的属性与创建矩阵
2018/09/10 Python
NLTK 3.2.4 环境搭建教程
2018/09/19 Python
在PyCharm中实现添加快捷模块
2020/02/12 Python
使用HTML5原生对话框元素并轻松创建模态框组件
2019/03/06 HTML / CSS
TUMI马来西亚官方网站:国际领先的高品质商旅箱包品牌
2018/04/26 全球购物
莫斯科大型旅游休闲商品超市:Camping.ru
2020/09/16 全球购物
环保倡议书怎么写
2014/05/16 职场文书
幼儿园教师师德表现自我评价
2015/03/05 职场文书
李强优秀员工观后感
2015/06/16 职场文书
接触艺术对孩子学习思维有益
2019/08/06 职场文书
领导激励员工的演讲稿,各种会上用得到,建议收藏
2019/08/13 职场文书
分享几种python 变量合并方法
2022/03/20 Python