js 教你怎么封装 例如如何封装getElementsByClassName()方法

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div>我的爱人</div>
<div class="myClass">div</div>
<p class="myClass" id="myClass">p</p>
</body>
<script>
    function getClass(className){
        var bqAll=document.getElementsByClassName;
        if(bqAll){
            return document.getElementsByClassName(className)
        }
        var arr=[];
        var dom=document.getElementsByTagName("*");
        for(var i=0;i<dom.length;i++){
           var classArray=dom[i].className.split(" ");
            for(var j=0;j<classArray.length;j++){
                if(classArray[j]==className){
                    arr.push(dom[i]);
                }
            }
        }
        return arr;
    }
    function $(str){
        var s=str.charAt(0);//存放符号
        var ss=str.substr(1);//存放元素的id名或类名
        switch(s){
            case "#":
                    alert("封装");
                   return document.getElementById(ss);
                break;
            case ".":
                alert("类="+document.getElementsByClassName(ss)[0]);
                    return document.getElementsByClassName(ss)[0];
                break;
            default:
                    alert("str="+document.getElementsByTagName(str)[0]);
                return document.getElementsByTagName(str)[0];
        }
    }
//    $("p").innerHTML="我的p元素";
//    $("#myClass").style.backgroundColor="red";
    $(".myClass").style.color="blue";
</script>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值