推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
mopig

关于 this 的指向, 很是疑惑啊 %>_<%

  •  
  •   mopig · Jun 11, 2014 · 3622 views
    This topic created in 4381 days ago, the information mentioned may be changed or developed.


    搞不懂 bind 前面的 this 和后边的 this 各指向的对象.

    stackoverflow 上边看到的一段代码...
    9 replies    2014-06-11 22:05:04 +08:00
    superbear
        1
    superbear  
       Jun 11, 2014   ❤️ 1
    看不懂可以把this存到一个变量里例如,var _this = this。
    lijsh
        2
    lijsh  
       Jun 11, 2014   ❤️ 3
    两个this都是同一个对象,就是以new调用MyObject时返回的实例对象。

    添加事件处理函数时,当前作用域会丢失(即this会指向全局对象),因此这里要把this.onClick绑定回当前的this中。

    还有一种会丢失作用域的情况是定时函数,所以如果想保存原来的上下文,同样需要为定时函数添加this绑定。
    exoticknight
        3
    exoticknight  
       Jun 11, 2014   ❤️ 1
    很多时候主要是代码运行的环境不一样导致this的指向变了,比如onclick执行的时候不是在你代码运行的时候而是你点击的时候。
    mopig
        4
    mopig  
    OP
       Jun 11, 2014
    @superbear 谢谢

    @lijsh 解释很清楚, 太感谢了
    superbear
        5
    superbear  
       Jun 11, 2014
    @lijsh 哦,在看不懂的情况话,我就会将this对象赋给一个变量,供之后使用
    lijsh
        6
    lijsh  
       Jun 11, 2014
    @superbear 一般this会丢失的情况就几种,闭包里,还有就是事件处理函数和定时函数,其他情况下不怎么需要保存这个this
    pepsin
        7
    pepsin  
       Jun 11, 2014
    尽量避免用
    mcfog
        8
    mcfog  
       Jun 11, 2014
    之前正好写了一篇关于this指向的文章 http://mcfog.github.io/2014/05/easy-ecma-1/

    比起解释this,更多的是教你看ecma标准,希望对你有帮助
    superbear
        9
    superbear  
       Jun 11, 2014
    @lijsh 哦,比如经常在ajax传数据的时候用这种方法
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5437 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 86ms · UTC 07:09 · PVG 15:09 · LAX 00:09 · JFK 03:09
    ♥ Do have faith in what you're doing.