Accessing variable inside object property

那年仲夏 提交于 2019-12-31 01:59:10

问题


So I encountered a problem. I have this object called myTree. And that object has properties. One of the properties contains a method like this:

prep: function (variable) {
    /* some code */
}

In that method there is an array myarray and I want to know, whether it is possible to access the content of that array, and if it is, how I would do that.

I've made a demo on jsFiddle, and in the end of the JavaScript window you can see that I'm alerting the object prep in which myarray is contained.

http://jsfiddle.net/Wp7Xh/1/


回答1:


JavaScript variables are function-scoped. It is not possible to access variables belonging to an inner scope (i.e. "function") from an outer scope.

If you want that kind of access, you must make the respective variable part of the outer scope.

var myTree = function() {
  var myarray = [];

  this.prep = function (variable) {
    myarray.push(variable);
  };
}

In your scenario, where you have nested objects, it's quite similar:

var myTree = {
  myarray: [],
  prep: function (variable) {
    this.myarray.push(variable);
  }
}

The only difference is the use of the this keyword.

When you define an object via the object literal syntax (obj = {prop: value}) instead of via a constructor (function Obj(value) { this.prop = value; }; obj = new Obj(value);), then all defined properties will be "public" by default.

When you call a function on that object, this will point to the respective object instance.

Accessing an "inner scope" variable from outside is still impossible. There's no way around that.

Generally speaking: You can access properties of the objects you construct. You can never access function local variables (except from the inside of nested functions).



来源:https://stackoverflow.com/questions/11291323/accessing-variable-inside-object-property

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!