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

时间:2013-02-02 21:16:31

标签: javascript prototype

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

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

但是如果你不能使用jQuery怎么办?

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

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

我可以这样做:

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

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

2 个答案:

答案 0 :(得分:28)

这是让你入门的东西:

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,原型将会更新。

但请注意,这不是jQuery的真正替代品,因为我在此代码中没有包含很多内容。 wrap函数在很多方面都不如jQuery的$高级且有用。

我希望这会有所帮助。

答案 1 :(得分:3)

刚刚写了样板文件。它没有自己的选择器逻辑,因为它是为已经拥有自己的选择器引擎的D3.js上的库设计的。 https://gist.github.com/turboMaCk/34bde8e744f5921be0c4