在另一个函数中访问变量,返回未定义的 - JavaScript



我正在尝试访问另一个函数中存在的变量,但我无法访问,它为我正在这样做的函数(getMess() 如下)提供了未定义的函数。根据下面的代码,我希望通过myfunction1访问"value1",如下所示。法典:

var namespace ={
    myfunction1: function(){
        namespace.myfunction2.getMess();   // I need to access value1 here in this function
    },
    myfunction2: function(message1,message2){
        var value1 = message1;
        var value2 = message2;
        return{
          getMess: function(){ return value1;}
          getLab: function() { return value2;}
        }
    }
}
namespace.myfunction2("hello","bye"); // this basically just sets the 2 values on page load

我刚刚发布了另一个带有原始问题的问题:在javascript中读取资源文件条目 - MVC应用程序

你可以做:

myfunction2: function(message1,message2){
    var value1 = message1;
    var value2 = message2;
    namespace.myfunction2.getMess: function(){ return value1;}
    namespace.myfunction2.getLab: function() { return value2;}
}

但这非常糟糕(将属性分配给函数对象)。最好使用模块模式重构整个事情来模拟私有和特权成员。

例如

var namespace = (function() {
    // Private members
    var value1, value2;
    return {
      // Privileged methd to read private member values
      fn1: function() {
        return namespace.fn2.getMess1();
      },
      // Privileged methods to set and get private member values
      fn2: {
        setMess: function(message1, message2) {
          value1 = message1;
          value2 = message2;
        },
        getMess1: function() {
          return value1;
        },
        getMess2: function() {
          return value2;
        }
      }
    }
}());
namespace.fn2.setMess("hello","bye");
alert(namespace.fn1()); // hello

对我来说似乎很奇怪,但首先你正在重新调整一个对象,并在你试图返回的 2 个函数之间缺少一个,

var namespace ={
    myfunction1: function(){
        var jamie = namespace.myfunction2("hello","bye");   // save returned value so we can use them later.
        console.info(jamie.getMess); //as we already executed the value just refer to them
    },
    myfunction2: function(message1,message2){
        var value1 = message1;
        var value2 = message2;
        return{
          getMess: function(){ return value1;}(), //return self executing functions to return values without the need to run them again.
          getLab: function(){ return value2;}()
        }
    }
}
namespace.myfunction1();

虽然我仍然不确定您要实现什么,但我如何在 2 个函数之间传递值,同时不向namespace声明变量,而只是以这种方式全局分配值。

相关内容

  • 没有找到相关文章

最新更新