我正在尝试访问另一个函数中存在的变量,但我无法访问,它为我正在这样做的函数(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
声明变量,而只是以这种方式全局分配值。