首页 > Web开发 > 详细

JS初学——this的学习及简单运用

时间:2016-07-01 01:17:16      阅读:325      评论:0      收藏:0      [点我收藏+]

 

技术分享
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <script type="text/javascript">
            window.onload = function (){
                var obtn = document.getElementById("btn");
                function fn(){
                    alert(this);
                }
                fn();
                obtn.onclick = fn;
            }
        </script>
    </head>
    <body>
        <input type="button" name="btn" id="btn" value="按钮" />
    </body>
</html>
view code

this指的是调用当前方法(函数)的对象,也可以理解为谁让函数运行,谁就是这个this.

 

var obtn = document.getElementById("btn");
obtn.onclick = function(){
                    this;
                }

  很明显,调用当前匿名函数的对象为obtn

window.onload = function (){
                var obtn = document.getElementById("btn");
                function fn(){
                    this;
                }
                fn();
                obtn.onclick = function(){
                    fn();
                }
            }

  而当obtn里面调用了另外一个函数,那么fn的对象仍然为window.

  理解:

技术分享
<script type="text/javascript">
            window.onload = function (){
                var abtn = document.getElementsByTagName("input");
                for(var i = 0; i<abtn.length;i++){
                    abtn[i].onclick = function(){
                    this.style.backgroundColor = "yellow";
                    }
                }
            }
        </script>
    </head>
    <body>
        <input type="button" name="btn1" id="btn1" value="按钮" />
        <input type="button" name="btn2" id="btn2" value="按钮" />
        <input type="button" name="btn3" id="btn3" value="按钮" />
    </body>
View Code

  this指的是obtn对应的input标签

 

技术分享
<script type="text/javascript">
            window.onload = function (){
                var abtn = document.getElementsByTagName("input");
                var that = null;
                for(var i = 0; i<abtn.length;i++){
                    abtn[i].onclick = function(){
                    that = this;
                    fn();
                    }
                }
                function fn(){
                    that.style.backgroundColor = "yellow";
                }
            }
        </script>
    </head>
    <body>
        <input type="button" name="btn1" id="btn1" value="按钮" />
        <input type="button" name="btn2" id="btn2" value="按钮" />
        <input type="button" name="btn3" id="btn3" value="按钮" />
    </body>
View Code

  可以先定义一个空元素,通过把当前this所对应的对象保存到空元素中,然后在另外的一个函数中实现出来。

技术分享
<script type="text/javascript">
            window.onload = function (){
                var abtn = document.getElementsByTagName("input");
                var that = null;
                for(var i = 0; i<abtn.length;i++){
                    abtn[i].onclick = fn;
                }
                function fn(){
                    this.style.backgroundColor = "yellow";
                }
            }
        </script>
    </head>
    <body>
        <input type="button" name="btn1" id="btn1" value="按钮" />
        <input type="button" name="btn2" id="btn2" value="按钮" />
        <input type="button" name="btn3" id="btn3" value="按钮" />
    </body>
View Code

  这是另外一种用法。

 

JS初学——this的学习及简单运用

原文:http://www.cnblogs.com/running-wsnail/p/5631559.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!