我在http://docs.jquery.com/Plugins/Authoring
上定义了我的插件(function( $ ){
var methods = {
init : function( options ) { },
show : function( options ) { },
hide : function( ) { },
update : function( content ) {
// How to call the show method inside the update method
// I tried these but it does not work
// Error: not a function
this.show();
var arguments = { param: param };
var method = 'show';
// Error: options is undefined
methods[ method ].apply( this, Array.prototype.slice.call( arguments, 1 ));
}
};
$.fn.tooltip = function( method ) {
// Method calling logic
if ( methods[method] ) {
return methods[ method ].apply( this, Array.prototype.slice.call( arguments, 1 ));
} else if ( typeof method === 'object' || ! method ) {
return methods.init.apply( this, arguments );
} else {
$.error( 'Method ' + method + ' does not exist on jQuery.tooltip' );
}
};
})( jQuery );
如何在update方法中调用show方法?
修改:
show
方法引用this
。使用methods.show(options)
或methods['show'](Array.prototype.slice.call( arguments, 1 ));
可以调用show
方法,但是对this
的引用似乎是错误的,因为我遇到了this.find(...) is not a function
错误。
show
方法:
show: function(options) {
alert("Options: " + options);
alert("Options Type: " + options.interactionType);
var typeCapitalized = capitalize(options.interactionType);
var errorList = this.find('#report' + typeCapitalized);
errorList.html('');
},
答案 0 :(得分:14)
var methods = {
init : function( options ) { },
show : function( options ) { },
hide : function( ) { },
update : function( options ) {
methods.show.call(this, options);
}
};
答案 1 :(得分:1)
你使用.apply
就是把所有东西扔掉。您故意更改 this
的含义,这是this.show()
无效的原因。如果您希望this
继续methods
(这是有道理的),您可以做到:
return methods[ method ](Array.prototype.slice.call( arguments, 1 ));