【问题标题】:Modifying javascript class attributes修改 javascript 类属性
【发布时间】:2015-06-04 23:38:25
【问题描述】:

我在这里要做的是,我有以下课程 Session

function Session(){
    this.accounts = {};
    this.setupAccounts = function(res){
        this.accounts = res;
        log(res);
        log(this.accounts);
    };

    this.test = function(){
        log(this.accounts);
    };
}

Session类有一个属性accounts,用来保存一些数据。但是为了初始化它,我将它初始化为一个空对象。

接下来我调用setupAccounts方法来修改accounts的值。例如,我读取一个文件,加载它的数据,然后将该数据存储在帐户中。

但是我遇到了范围问题。

例如下面的代码:

var session = new Session();
var user_account_path = '/adata/user_accounts.json';
loadJsonFile(user_account_path)
     .then(session.setupAccounts);
session.test();

所以我在上面的代码中所做的是将文件的内容作为 Json 对象获取,然后我将该数据传递给方法 setupAccounts 以便将该数据存储在变量帐户中。但我的输出如下所示:

Object {arjrule3: Object}  // printing the json object read from file
Object {arjrule3: Object}  // locally changed value of accounts
console.log(session.accounts) // printing global value of accounts
{} // value has not changed. 

我做错了什么?为什么对象会话的帐户值没有改变?

刚刚发生了一些有趣的事情,如果我将代码编写如下:

var session = new Session();
var user_account_path = '/adata/user_accounts.json';
loadJsonFile(user_account_path)
   .then(function(res){
      session.setupAccounts(res);  // Change Here
   });

输出:

Object {arjrule3: Object}
Object {arjrule3: Object}
session.accounts
Object {arjrule3: Object}  // works! Why ?

它有效,为什么会这样?

【问题讨论】:

    标签: javascript object-oriented-analysis


    【解决方案1】:
    var session = new Session();
    var user_account_path = '/adata/user_accounts.json';
    loadJsonFile(user_account_path)
     .then(session.setupAccounts);
    session.test();
    

    在上面的示例中,您只是将函数“setupAccounts”作为回调传递。您需要先绑定它,例如

    var session = new Session();
    var user_account_path = '/adata/user_accounts.json';
    loadJsonFile(user_account_path)
     .then(session.setupAccounts.bind(session));
    session.test();
    

    您添加的另一个示例有效,因为您在会话对象上调用“setupAccounts”函数,而不仅仅是传递对它的引用。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-01-05
      • 1970-01-01
      • 1970-01-01
      • 2011-05-25
      相关资源
      最近更新 更多