jQuery插件开发-为什么要用extend()方法?

发布于 2022-09-02 13:38:35 字数 183 浏览 11 评论 0

我知道jQuery插件开发中有一种是extend,是合并对象用的。
为什么要用jQuery.extend() 的方法扩展jQuery方法?
而不是直接用jQuery.pluginname = function(){} 这样的方法?
在我看来这两种都是直接在jQuery命名空间下加一个方法,那为什么更推荐使用extend方法来扩展??

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

与酒说心事 2022-09-09 13:38:35

先回答你的问题:
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 plugin
https://learn.jquery.com/plugins/basic-plugin-creation/

$.extend和$.fn.extend的区别
http://www.cnblogs.com/wang_yb/archive/2014/11/17/4103137.html

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文