我正在尝试在一个简单的jquery插件中调用一个函数。我看到init方法将宽度加30,但add50方法抛出错误Uncaught TypeError: Object [object Object] has no method 'add50'
。不确定导致此错误发生的原因。
jsfiddle:http://jsfiddle.net/nsshrinivasan/KnDMq/6/
;(function ( $, window, document, undefined ) {
// Create the defaults once
var pluginName = 'Extender',
defaults = {
propertyName: "value"
};
// The actual plugin constructor
function Plugin( element, options ) {
this.element = element;
this.options = $.extend( {}, defaults, options) ;
this._defaults = defaults;
this._name = pluginName;
this.init(this.element);
}
Plugin.prototype = {
init : function (element) {
// console.log($(this.element).width());
$(element).width($(element).width() + 30);
},
add50 : function(element){
$(element).width($(element).width() + 50);
}
};
$.fn[pluginName] = function ( options ) {
return this.each(function () {
if (!$.data(this, 'plugin_' + pluginName)) {
$.data(this, 'plugin_' + pluginName,
new Plugin( this, options ));
}
});
}
})( jQuery, window, document );
$('#metal').Extender().add50();
HTML:
<div id='metal'></div>
CSS:
#metal{
width: 50px;
height: 10px;
background:red;
}
答案 0 :(得分:1)
尝试添加以下内容:
function Plugin( element, options ) {
this.element = element;
this.options = $.extend( {}, defaults, options) ;
this._defaults = defaults;
this._name = pluginName;
if (this[options]){
this[options](this.element);
} else {
this.init(this.element);
}
}
然后您可以使用以下所有插件:$('#metal').Extender('add50');
并将您的方法作为选项传递。
jsFiddle Update
答案 1 :(得分:1)
我更新了你的小提琴:Fiddle
;(function ( $, window, document, undefined ) {
// Create the defaults once
var pluginName = 'Extender',
defaults = {
propertyName: "value"
};
// The actual plugin constructor
function Plugin( element, options ) {
this.element = element;
this.options = $.extend( {}, defaults, options) ;
this._defaults = defaults;
this._name = pluginName;
this.init();
}
Plugin.prototype = {
init : function () {
// console.log($(this.element).width());
$(this.element).width($(this.element).width() + 30);
},
add50 : function(){
$(this.element).width($(this.element).width() + 50);
}
};
$.fn[pluginName] = function ( options ) {
return $.data(this, 'plugin_' + pluginName, new Plugin( this, options ));
}
})( jQuery, window, document );
$('#metal').Extender().add50();