网站首页  汉语字词  英语词汇  考试资料  写作素材  旧版资料

请输入您要查询的考试资料:

 

标题 常见的原始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);
    }
随便看

 

在线学习网考试资料包含高考、自考、专升本考试、人事考试、公务员考试、大学生村官考试、特岗教师招聘考试、事业单位招聘考试、企业人才招聘、银行招聘、教师招聘、农村信用社招聘、各类资格证书考试等各类考试资料。

 

Copyright © 2002-2024 cuapp.net All Rights Reserved
更新时间:2025/5/17 0:34:29