您好,欢迎访问一九零五行业门户网

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

常见的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 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 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);
}
其它类似信息

推荐信息