原生js事件简化

<!doctype html>
<html lang="en">

<head>
    <meta charset="UTF-8" />
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
        
        .box {
            width: 200px;
            height: 200px;
            background: skyblue;
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%, -50%);
            bottom: 0;
        }
        
        .bd {
            text-align: center;
        }
    </style>
</head>

<body>
    <div class="bd">
        <div class="box"></div>

        <button class="changeWidth">变宽</button>
        <button class="changeHeight">变高</button>
        <button class="changeColor">变色</button>
        <button class="changeHide">隐藏</button>
        <button class="back">重置</button>

    </div>

    <script>
                var changeWidth= document.getElementsByClassName('changeWidth')[0].onclick=function(){
                      document.getElementsByClassName('box')[0].style.width=300+'px'
                }; 
                document.getElementsByClassName('changeHeight')[0].onclick=function(){
                      document.getElementsByClassName('box')[0].style.height=300+'px'
                }; 
                document.getElementsByClassName('changeColor')[0].onclick=function(){
                 document.getElementsByClassName('box')[0].style.background="blue"
                     
                }; 
                document.getElementsByClassName('changeHide')[0].onclick=function(){
                      document.getElementsByClassName('box')[0].style.display="none"
                }; 
                
                document.getElementsByClassName('back')[0].onclick=function(){
                     document.getElementsByClassName('box')[0].style.cssText=""
                      document.getElementsByClassName('box')[0].style.display="block"
                };

    </script>
</body>

</html>

像这样一个个的改变style太过于麻烦,我们可以将代码精简,用循环来减少代码的重复

<script>
 window.onload = function() {
                let btn = document.getElementsByTagName('button');
                let odiv = document.getElementsByClassName('box')[0];

                let change = ['width', 'height', 'background', 'display', 'display'];
                let value = ['300px', '300px', 'blue', 'none', 'block']
                for(let i = 0; i < btn.length; i++) {
                    btn[i].onclick = function() {
                        if(i==4){
                            odiv.style.cssText = ""
                        }
                        
                        odiv.style[change[i]] = value[i]
                    }

                }

            }
        </script>

代码的发展必然是越来越精简 运行速度越来越快的 所以平时写完代码后要用心观察 思考如何精简这样才是个合格的程序猿

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 177,386评论 25 709
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,004评论 1 92
  • 前几天被各大公众号疯狂转载的一篇文章,叫《摩拜创始人套现15亿背后,你的同龄人,正在抛弃你》,在看到这个标题的时候...
    坚果小姐姐阅读 1,013评论 0 2
  • 不眠夜
    岁月静好lalala阅读 137评论 0 0
  • 今天整理了一个小角落。 好好的花儿被我堆放在一边,箱子大开门。我把花放进米酒瓶里,放上我的书桌。 清理箱...
    益西卓玛阅读 277评论 0 0

友情链接更多精彩内容