javascript - promise 中绑定(bind)参数的状态

标签 javascript state lifecycle page-lifecycle

我很好奇我将某些东西绑定(bind)到 promise 的时机。

var that = this;
function p(){

    var promise = new Promise(
        function (yes, no) {
        /* ....  */
        /* ....  */
        }).then(function (val) {
        /* ....  */
        /* ....  */
        }.bind(this));
}.bind(this)

请问条件

that === this

总是返回 true,考虑到 promise 之外的范围是异步的,.then 可能会在生命周期的后期解决。

换句话说,this 是否与调用第一个函数时具有相同的值,或者它是否具有在 .then 中实际使用的值部分?

最佳答案

this 的值由调用方法中点左边的内容决定。如果您不调用对象的方法,则 this 将是全局的(浏览器中的窗口)。

在您的示例中,行var that = this 将that 的值设置为该全局变量window(或global)。所以在这种特定情况下,这将始终等于那个。然而,这是由于副作用,如果您使用不同的对象作为 this,那么在

function (yes, no) {
    /* ....  */
    /* ....  */
}

这个!==那个

我做了一个 fiddle 作为例子 http://jsfiddle.net/metaf0x9/

关于javascript - promise 中绑定(bind)参数的状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29931998/

相关文章:

android - 如何获取Android拨出电话的通话状态

haskell - 有没有一种明智的方法来解压缩状态单子(monad)?

javascript - Shinydashboard:使侧边栏在主体上方打开而不是挤压主体

javascript - 在 iframe 中更改页面的按钮或链接

reactjs - 如果我没有更改状态的引用,为什么 React 会调用渲染函数?

java - Vaadin 中布局(或组件)的生命周期?

java - Akka Actor 生命周期

java - Android 在循环进程运行时不调用 onPause 和 onStop

Javascript -> 添加同名嵌套对象的值

javascript - Pg-promise - 可能参与事务/任务的可重用查询