84669 orang belajar
152542 orang belajar
20005 orang belajar
5487 orang belajar
7821 orang belajar
359900 orang belajar
3350 orang belajar
180660 orang belajar
48569 orang belajar
18603 orang belajar
40936 orang belajar
1549 orang belajar
1183 orang belajar
32909 orang belajar
我知道jQuery插件开发中有一种是extend,是合并对象用的。为什么要用jQuery.extend() 的方法扩展jQuery方法?而不是直接用jQuery.pluginname = function(){} 这样的方法?在我看来这两种都是直接在jQuery命名空间下加一个方法,那为什么更推荐使用extend方法来扩展??
光阴似箭催人老,日月如移越少年。
先回答你的问题:jQuery.extend({pluginname: function() {}})和jQuery.pluginname = function() {}没有什么区别,都是去扩展了jQuery本身,也就是$对象,只是前者会在定义多个plugin时方便点:
$
// without jQuery.extend() jQuery.pluginA = function() {}; jQuery.pluginB = function() {}; jQuery.pluginC = function() {}; // with jQuery.extend() jQuery.extend({ pluginA: function() {}, pluginB: function() {}, pluginC: function() {} });
其实这个和模拟类时怎样扩展prototype是一样的:
// 有人这么写 function ClassA() {} ClassA.prototype.funcA = function() {}; ClassB.prototype.funcB = function() {}; // 也有人这么写 function ClassB() {} ClassB.prototype = { constructor: ClassB, funcA: function() {}, funcB: function() {} };
更多参考:
怎样创建jQuery pluginhttps://learn.jquery.com/plugins/basic-plugin-creation/
$.extend和$.fn.extend的区别http://www.cnblogs.com/wang_yb/archive/2014/11/17/4103137.html
先回答你的问题:
jQuery.extend({pluginname: function() {}})和jQuery.pluginname = function() {}没有什么区别,都是去扩展了jQuery本身,也就是
$
对象,只是前者会在定义多个plugin时方便点:其实这个和模拟类时怎样扩展prototype是一样的:
更多参考:
怎样创建jQuery plugin
https://learn.jquery.com/plugins/basic-plugin-creation/
$.extend和$.fn.extend的区别
http://www.cnblogs.com/wang_yb/archive/2014/11/17/4103137.html