javascript - 如何在没有 jQuery 的情况下编写 javascript 插件

标签 javascript prototype

使用 jQuery 编写插件相对容易,只需使用 $.fn 即可。像这样:

$.fn.analyse = function() {
...
}

但是如果您不会使用 jQuery 怎么办?

假设我希望能够使用以下代码:

document.querySelector("#mydiv").analyse();

我可以这样做:

Object.prototype.analyse = function() {
...
}

但据我所知,这是不受欢迎的!

最佳答案

这里有一些可以帮助您入门的内容:

var proto_methods = {
    analyse: function() {
        var node = this.node;

        // ...
    }
}, wrap, _wrap;

_wrap = function(selector) { this.node = document.querySelector(selector); };
_wrap.prototype = proto_methods;

wrap = function(selector) {
    return new _wrap(selector);
};

像这样使用它:

wrap("#mydiv").analyse();

如果你想添加更多插件(并且它更面向对象),请使用它:

var pack = {
    binder: [{}]
};

pack.query_bind = function( bound ) {
    if (bound) pack.binder[1] = bound;
};

pack.fn = function( attributes ) {
    for (var i in attributes) pack.binder[0][i] = attributes[i];
};

var _wrap = function(selector) {
    this.node = /^(#|.)\w+/.test(selector) ? pack.binder[1](selector) : {};
};

_wrap.prototype = pack.binder[0];

var wrap = function(selector) {
    pack.query_bind(document.querySelector.bind(document));
    return new _wrap(selector);
};

wrap.fn = pack.fn;

wrap.fn({
    cool: function() {},
    nice: function() {}
});

wrap('#mydiv').cool();

您可以随时调用wrap.fn,原型(prototype)将被更新。

但是请注意,这并不是 jQuery 的真正替代品,因为有很多东西我没有包含在这段代码中。 wrap 函数在许多方面不如 jQuery 的 $ 先进和有用。

希望对您有所帮助。

关于javascript - 如何在没有 jQuery 的情况下编写 javascript 插件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14666608/

相关文章:

javascript - NPM 注册表安装在非注册表依赖项上失败

javascript - 在 MongoDB 3.6 NodeJS 驱动程序中断言?以及在使用promise实现时如何使用assert?

javascript - 如何使用 Grunt 而不将所有内容压缩到单个文件中

new Object([])/new Object(new Array()) 的 JavaScript 构造函数

Javascript:数组成员变量在原型(prototype)继承中不作为实例变量工作

javascript - 如何切换 div 的存在而不是可见性

php - json 中按日期列每周 header

javascript - 为什么 JavaScript 对象的这个扩展不起作用?

javascript - 在同一个声明中创建javascript函数和原型(prototype)定义?

JavaScript 数组原型(prototype), 'this' 没有 'push' 方法