ここにあなたが始めるための何かがあります:
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 ほど高度でも有用でもありません。
これが役立つことを願っています。