我有一个创建 Widget 对象的 Factory 类。工厂对象稍后需要回调 Widget 对象的“私有(private)方法”,以向其传递一些 ajax 信息。到目前为止,我想出的唯一实现是在 Widget 中创建一个公共(public)方法,该方法将私有(private)方法返回给工厂,然后删除自己,然后工厂返回新的 Widget,同时保留指向私有(private)方法的指针.这是一个简化的示例:
function Factory()
{
var widgetCallback = null;
this.ajaxOperation = function()
{
//some ajax calls
widgetCallback('ajaxresults');
}
this.getNewWidget = function()
{
var wid = new Widget();
widgetCallback = wid.getCallback();
return wid;
}
function Widget()
{
var state = 'no state';
var self = this;
var modifyState = function(newState)
{
state = newState;
}
this.getState = function()
{
return state;
}
this.getCallback = function()
{
delete self.getCallback;
return modifyState;
}
}
}
有没有更好的方法来实现我所追求的效果,或者这是一种相当合理的方法?我知道它有效,只是想知道我是否步入了我应该注意的任何陷阱。
最佳答案
this.getNewWidget = function() {
var val = new Widget(),
wid = val[0],
widgetCallback = val[1];
return wid;
}
function Widget() {
var state = 'no state';
var self = this;
var modifyState = function(newState) {
state = newState;
}
this.getState = function() {
return state;
}
// Return tuple of Widget and callback
return [this, modifyState];
}
只需让您的构造函数返回
Tuple<Widget, function>
替代方法只是使用闭包范围直接在您的
widgetCallback
构造函数中编辑 Widget
function Factory() {
var widgetCallback = null;
this.ajaxOperation = function() {
//some ajax calls
widgetCallback('ajaxresults');
}
this.getNewWidget = function() {
return new Widget();;
}
function Widget() {
var state = 'no state';
var self = this;
// set it directly here!
widgetCallback = function(newState) {
state = newState;
}
this.getState = function() {
return state;
}
}
}
关于javascript - javascript 中的 "Friend Classes",我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/6423918/