zoukankan      html  css  js  c++  java
  • 原始JS选择器使用方法总结

    原始JS选择器使用方法总结

    常见的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年实现,可见老外许多东西在很早以前就走得很远了。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    //三个参数都是必需的,查找一网页中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。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    //后两参数是可靠的,查找一网页中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);
      }

  • 相关阅读:
    JAVA Number类
    ConcurrentHashMap.Segment源码解析
    Java Concurrent包初探
    JAVA枚举类
    构造不可变类及其优点
    Unsafe类初探
    Paxos made simple 翻译尝试
    平行二叉堆和优先队列
    Android OpenCV学习
    Android-Java和HTML5交互-混合开发-优化
  • 原文地址:https://www.cnblogs.com/shsgl/p/4042336.html
Copyright © 2011-2022 走看看