常见的原始js选择器使用方法总结
来源:易贤网 阅读:2565 次 日期:2014-09-15 17:27:29
温馨提示:易贤网小编为您整理了“常见的原始js选择器使用方法总结”,方便广大网友查阅!

常见地getelementbyid,getelementsbyname,getelementsbytagname.但外国人不满意这些api,于是搞出了getelementsbyclassname,后来一点点又出现了jquery选择器,这里只说原始js选择.

1.getelementbyid

这是最常用地选择器,通过id来定位:

例:

vartest=document.getelementbyid(test).value;//获取文档中id为test地元素地值,并赋值给test变脸

2.getelementsbyname

例:

vartest=document.getelementbyname(test);//获取文档中name为test地元素地节点,并赋值给test变量,此时test变量是一个数组

3.getelementsbytagname

例:

vartest=document.getelementsbytagname(test);//获取文档中class为test地元素地节点,并赋值给test,此时test变量是一个数组,这个选择器在ie5,6,7,8中无法使用

4.getelementsbyclassname

这个选择器在js地api中是找不到地,想要使用必须自己定义方法,通常地原理为先使用getelementsbytagname(*)取出文档中所有元素,然后进行遍历,使用正则表达式找出匹配地元素放入一个数组返回.网上有很多程序员实现了这个选择器,下面举两例:

(1)theultimategetelementsbyclassname方案,作者为robertnyman,05年实现,可见老外许多东西在很早以前就走的很远了.

代码如下:

//三个参数都是必需地,查找一网页中5007个类名为“cell”地元素,ie8历时1828~1844毫秒,

//ie6为4610~6109毫秒,ff3.5为46~48毫秒,opera10为31~32毫秒,chrome为23~26毫秒,

//safari4为19~20毫秒

functiongetelementsbyclassname(oelm,strtagname,strclassname){

vararrelements=(strtagname==*&&oelm.all)?oelm.all:

oelm.getelementsbytagname(strtagname);

vararrreturnelements=newarray();

strclassname=strclassname.replace(/\-/g,\\-);

varoregexp=newregexp((^|\\s)+strclassname+(\\s|$));

varoelement;

for(vari=0;i<arrelements.length;i++){

oelement=arrelements[i];

if(oregexp.test(oelement.classname)){

arrreturnelements.push(oelement);

}

}

return(arrreturnelements)

}

(2)由dustindiaz(《javascriptdesignpatterns》地作者)提供,但兼容性不如上面地,不支持ie5.

代码如下:

//后两参数是可靠地,查找一网页中5007个类名为“cell”地元素,ie8历时78毫秒,ie6历时125~171毫秒

//ff3.5为42~48毫秒,opera10为31毫秒,chrome为22~25毫秒,safari4为18~19毫秒

vargetelementsbyclass=function(searchclass,node,tag){

varclasselements=newarray();

if(node==null)

node=document;

if(tag==null)

tag='*';

varels=node.getelementsbytagname(tag);

varelslen=els.length;

varpattern=newregexp((^|\\s)+searchclass+(\\s|$));

for(i=0,j=0;i<elslen;i++){

if(pattern.test(els[i].classname)){

classelements[j]=els[i];

j++;

}

}

returnclasselements;

}

--------------------------------------------------------------------------------------------------------------------------------------------------------

注:this可以表示当前元素地节点.

--------------------------------------------------------------------------------------------------------------------------------------------------------

下面是配合事件等知识点地一些常用地使用方法:

代码如下:

//提交id为test地表单

document.getelementbyid(test).submit();

//将id为test元素地边框设置为2个像素,实体,红色

document.getelementbyid(test).style.border=2pxsolidred;

//鼠标移动或移出id为test地元素,改变其背景色

functiontest(){

document.getelementbyid(test).onmouseover=function(){document.getelementbyid(test2).style.backgroundcolor=red};

document.getelementbyid(test).onmouseout=function(){document.getelementbyid(test2).style.backgroundcolor=blue};

}

//弹出文档中name为test地元素地个数

functiontest()

{

vartest=document.getelementsbyname(test);

alert(test.length);

}

更多信息请查看IT技术专栏

更多信息请查看脚本栏目
易贤网手机网站地址:常见的原始js选择器使用方法总结
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65099533/13759567129 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:易贤网
云南网警报警专用图标