[英]Extending jQuery Plugin default options with user's
在下面的演示中:这行代码中发生了什么?
settings = $.extend({}, defaultSettings, settings || {});
上面和这个之间有什么区别:
if(settings){
settings = $.extend(defaultSettings, settings);
}
==================================
(function($){
var defaultSettings = {
mode : 'Pencil',
lineWidthMin : '0',
lineWidthMax : '10',
lineWidth : '2'
};
$.fn.wPaint = function(settings)
{
settings = $.extend({}, defaultSettings, settings || {});
return this.each(function()
{
var elem = $(this);
//run some code here
});
}
})(jQuery);
settings = $.extend({}, defaultSettings, settings || {});
jQuery $ .extend()方法从右到左将一个或多个对象的属性复制到另一个对象中。 在此特定示例中,该方法正在传递三个对象: {}
(空对象), defaultSettings
然后settings
(如果settings
不存在,则为空对象)。 因此,从右到左,设置的所有属性都将被复制到defaultSettings
,然后将其结果复制到空对象( {}
)中。 所有这些的结果是settings
中的属性(用户的自定义选项)将优先于defaultSettings
,然后它们都被复制到空对象中。 空对象的原因是因为$ .extend()实际上通过引用修改了第一个参数,所以传入一个空对象作为第一个对象实际上是在不修改任何对象的情况下进行克隆。
if(settings){
settings = $.extend(defaultSettings, settings);
}
除了用空对象替换settings
(如果它不存在)之外,它不会执行给定的代码。
更新:关于settings || {}
settings || {}
,这意味着使用设置对象(如果它存在)(技术上,如果它是真实的) 或使用空对象。 它避免传递undefined
的值。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.