常见的原始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清理Word格式示例代码
Feb 13 Javascript
JavaScript阻止浏览器返回按钮的方法
Mar 18 Javascript
jQuery中extend()和fn.extend()方法详解
Jun 03 Javascript
JS+CSS实现大气的黑色首页导航菜单效果代码
Sep 10 Javascript
常用javascript表单验证汇总
Jul 20 Javascript
JS如何判断是否为ie浏览器的方法(包括IE10、IE11在内)
Dec 13 Javascript
原生js封装二级城市下拉列表的实现代码
Jun 16 Javascript
jQuery制作圣诞主题页面 更像是爱情影集
Aug 10 Javascript
详解AngularJs中$resource和restfu服务端数据交互
Sep 21 Javascript
JavaScript两个变量交换值的实现方法
Mar 01 Javascript
Vue实现导航栏点击当前标签变色功能
Aug 19 Javascript
怎么理解wx.navigateTo的events参数使用详情
May 18 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 HtmlReplace输入过滤安全函数
2010/07/03 PHP
php采用curl实现伪造IP来源的方法
2014/11/21 PHP
PHP获取数组长度或某个值出现次数的方法
2015/02/11 PHP
超棒的javascript页面顶部卷动广告效果
2007/12/01 Javascript
实现连缀调用的map方法(prototype)
2009/08/05 Javascript
Javascript异步表单提交,图片上传,兼容异步模拟ajax技术
2010/05/10 Javascript
javascript textContent与innerText的异同分析
2010/10/22 Javascript
Javascript中的delete介绍
2012/09/02 Javascript
两种方法实现文本框输入内容提示消失
2013/03/17 Javascript
jquery validate 自定义验证方法介绍 日期验证
2014/02/27 Javascript
javascript获取函数名称、函数参数、对象属性名称的代码实例
2014/04/12 Javascript
jquery.hotkeys监听键盘按下事件keydown插件
2014/05/11 Javascript
深入理解JavaScript中的块级作用域、私有变量与模块模式
2016/10/31 Javascript
js实现右键自定义菜单
2016/12/03 Javascript
解决给dom元素绑定click等事件无效问题的方法
2017/02/17 Javascript
Bootstrap笔记之缩略图、警告框实例详解
2017/03/09 Javascript
element-ui中的select下拉列表设置默认值方法
2018/08/24 Javascript
使用Vue父子组件通信实现todolist的功能示例代码
2019/04/11 Javascript
Vue插件之滑动验证码
2019/09/21 Javascript
原生js实现碰撞检测
2020/03/12 Javascript
[53:10]2018DOTA2亚洲邀请赛 4.6 淘汰赛 VP vs VG 第一场
2018/04/11 DOTA
Python重新加载模块的实现方法
2018/10/16 Python
Python实现PyPDF2处理PDF文件的方法示例
2019/09/25 Python
appium+python adb常用命令分享
2020/03/06 Python
python报错: 'list' object has no attribute 'shape'的解决
2020/07/15 Python
解决python便携版无法直接运行py文件的问题
2020/09/01 Python
Pytorch自定义Dataset和DataLoader去除不存在和空数据的操作
2021/03/03 Python
欧洲最大的笔和书写专家:The Pen Shop
2017/03/19 全球购物
Bowflex美国官方网站:高级家庭健身器材
2017/12/22 全球购物
18岁生日感言
2014/01/12 职场文书
《狮子和兔子》教学反思
2014/03/02 职场文书
初中新生军训方案
2014/05/13 职场文书
教师见习总结范文
2015/06/23 职场文书
2015少先队大队辅导员工作总结
2015/07/24 职场文书
学困生帮扶工作总结
2015/08/13 职场文书
numpy array找出符合条件的数并赋值的示例代码
2022/06/01 Python