继好jQuery Plugins/Authoring说明我有一个小问题
(function($){
// Default Settings
var settings = {
var1: 50
, var2: 100
};
var methods = {
init : function (options) {
console.log(settings);
settings = $.extend(options, settings); // Overwrite settings
console.log(settings);
return this;
}
, other_func: function () {
return this;
}
};
$.fn.my_plugin = function (method) {
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.my_plugin');
}
};
})(jQuery);
如果我这样做
>>> $('my_element').my_plugin({var3: 60})
Before Object { var2=100, var1=50}
After Object { var3=60, var2=100, var1=50}
[ my_element ]
>>> $('my_element').my_plugin({var1: 60})
Before Object { var1=50, var2=100}
After Object { var1=50, var2=100}
[ my_element ]
为什么我的 var1
没有被覆盖?
最佳答案
你在你的 $.extend
中混淆了参数的顺序(目标应该在第一位),它应该是:
settings = $.extend(settings, options);
参见 this fiddle 和 docs for $.extend()
为避免混淆,您还可以像这样使用默认设置扩展您的设置:
methods.init = function(options){
var settings = $.extend({
key1: 'default value for key 1',
key2: 'default value for key 2'
}, options); // <- if no / undefined options are passed extend will simply return the defaults
//here goes the rest
};
关于javascript - jQuery - 插件选项默认 extend(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9995392/