javascript function中,this的问题

发布于 2022-08-29 19:38:06 字数 1005 浏览 21 评论 0

以下代码在点击“上”按钮触发时,topFunc()分别弹出数组内容和“undefined”,请问是为什么?绑定事件时函数的所有者被换掉了不再是window了吗?一直听大家说this指向当前对象的所有者,函数是声明时确定所有者还是执行时确定所有者?

<!DOCTYPE html>
<html>
<head>
   <title>2048 Hello Word</title>
   <script type="text/javascript" src="jquery.js"></script>


<script type="text/javascript">
      var base = [[0,0,0,0],[0,0,0,0],[0,0,0,0],[0,0,0,0]];
      //添加事件函数
      function addEvent(id,func){
        var obj = document.getElementById(id);
        if(obj.addEventListener){
            obj.addEventListener('click',func);
        }else{
          obj.attachEvent('onclick',func);
        }
      }
      
      function topFunc(){
        alert(window.base);
        alert(this.base);
      }

      $(function(){
        addEvent('top',topFunc);
      })
   </script>


</head>
<body>


<div>
    <button id='top'>上</button>
  </div>


</body>
</html>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

青芜 2022-09-05 19:38:06

this指向的是当前的作用域,不是指向当前的所有者。所有者和作用域是不同的概念。在浏览器的javascript环境中,只有两个作用域,windowfunction

分析你的代码

var base = [[0,0,0,0],[0,0,0,0],[0,0,0,0],[0,0,0,0]];

是在window的作用域下声明的,所以直接被绑定到了window对象上去。

单论topFunc这个方法里面,this是指向当前的topFunc的,不是指向window的,所以this.base获得不了外围绑定在window对象上的base

[修正]
这里使用了addEventListener,那么情况又有所变化,它的回调应该被指向#topdom,其回调类似于:topFunc.call(dom, e),此时在topFunc的作用域已经改变指向了#topdom,可以用this.id看到输出是top来证明

[补充]
在一个对象中写一个函数,函数中使用this,可以找到对象的一个属性,这个该怎么解释?

说到一个概念叫做作用域,简单来讲js内部一个对象都有一个内部的属性[[scope]],当我声明 var A = {}; var B = A;的时后,A和B的作用域链已经被串起来了。

推荐几篇文章

最后一篇是ecmascript的官方文档,有指导意义

作用域的定义,这个问题有点大,各种语言都用不同定义。我理解为命名空间和局部变量的定义作用区间。这个倒是可以看看wiki怎么说,能力有限,这个问题回答不完整

爱已欠费 2022-09-05 19:38:06

这里的this指向id='top'的DOM对象.

不确定this指向什么可以console.log(this)打印一下看看, 根据结果再想想为什么!

你げ笑在眉眼 2022-09-05 19:38:06

我觉得楼主可能把属性和变量混淆了,变量是在所在的作用域里找不到就会在外层的作用域里去找,依次类推,直到全局作用域,而属性并不会到外层作用域里去找,就像楼主所给的代码,this.base ,base是一个属性,而不是一个变量,所以,this所指代的func没有base这个属性,所以是 undefined.而window.base就和作用域没一毛钱关系,它就是指向的全局对象window的base变量(全局对象里定义的变量都是全局对象的属性)。
看来多回答问题还是挺有用的,我想起我刚开始研究原生JS时把这些混淆了的原因了,我之前就是概念没搞清楚,不知道楼主是不是也是一样的情况。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文