gpt4 book ai didi

jquery - 为什么要将 jquery.fn 对象传递给 jqueryobject

转载 作者:行者123 更新时间:2023-12-01 04:31:39 24 4
gpt4 key购买 nike

我仍在尝试了解插件程序 这样我就可以自己编写或改编另一个。

我尝试向这个插件学习它使用 fn.extend 设置方法,然后将其自身(使用此)传递给某个函数在 jquery.extend 中制作。

jQuery.fn.extend({
everyTime: function(interval, label, fn, times) {
return this.each(function() {
jQuery.timer.add(this, interval, label, fn, times);
});
},

我还看到其他插件不这样做。

这是为什么?或者它背后的想法是什么。

(我读了一些其他解释,说一个用于函数,另一个用于方法,但这对我来说很模糊。)

谢谢理查德

编辑

使用两个不同扩展的完整插件代码

jQuery.fn.extend({
everyTime: function(interval, label, fn, times) {
return this.each(function() {
jQuery.timer.add(this, interval, label, fn, times);
});
},
oneTime: function(interval, label, fn) {
return this.each(function() {
jQuery.timer.add(this, interval, label, fn, 1);
});
},
stopTime: function(label, fn) {
return this.each(function() {
jQuery.timer.remove(this, label, fn);
});
}
});

jQuery.extend({
timer: {
global: [],
guid: 1,
dataKey: "jQuery.timer",
regex: /^([0-9]+(?:\.[0-9]*)?)\s*(.*s)?$/,
powers: {
// Yeah this is major overkill...
'ms': 1,
'cs': 10,
'ds': 100,
's': 1000,
'das': 10000,
'hs': 100000,
'ks': 1000000
},
timeParse: function(value) {
if (value == undefined || value == null)
return null;
var result = this.regex.exec(jQuery.trim(value.toString()));
if (result[2]) {
var num = parseFloat(result[1]);
var mult = this.powers[result[2]] || 1;
return num * mult;
} else {
return value;
}
},
add: function(element, interval, label, fn, times) {
var counter = 0;

if (jQuery.isFunction(label)) {
if (!times)
times = fn;
fn = label;
label = interval;
}

interval = jQuery.timer.timeParse(interval);

if (typeof interval != 'number' || isNaN(interval) || interval < 0)
return;

if (typeof times != 'number' || isNaN(times) || times < 0)
times = 0;

times = times || 0;

var timers = jQuery.data(element, this.dataKey) || jQuery.data(element, this.dataKey, {});

if (!timers[label])
timers[label] = {};

fn.timerID = fn.timerID || this.guid++;

var handler = function() {
if ((++counter > times && times !== 0) || fn.call(element, counter) === false)
jQuery.timer.remove(element, label, fn);
};

handler.timerID = fn.timerID;

if (!timers[label][fn.timerID])
timers[label][fn.timerID] = window.setInterval(handler,interval);

this.global.push( element );

},
remove: function(element, label, fn) {
var timers = jQuery.data(element, this.dataKey), ret;

if ( timers ) {

if (!label) {
for ( label in timers )
this.remove(element, label, fn);
} else if ( timers[label] ) {
if ( fn ) {
if ( fn.timerID ) {
window.clearInterval(timers[label][fn.timerID]);
delete timers[label][fn.timerID];
}
} else {
for ( var fn in timers[label] ) {
window.clearInterval(timers[label][fn]);
delete timers[label][fn];
}
}

for ( ret in timers[label] ) break;
if ( !ret ) {
ret = null;
delete timers[label];
}
}

for ( ret in timers ) break;
if ( !ret )
jQuery.removeData(element, this.dataKey);
}
}
}
});

jQuery(window).bind("unload", function() {
jQuery.each(jQuery.timer.global, function(index, item) {
jQuery.timer.remove(item);
});
});

最佳答案

这就是插件机制的工作原理。您可以通过使用自己的函数扩展 jQuery.fn 对象来创建 jQuery 插件。可以直接向 jQuery.fn 对象添加函数,也可以调用 jQuery.fn.extend()

这些插件函数始终将 jQuery 对象(即调用它的 DOM 元素的选择)作为 this 变量传递。

例如,假设您要创建一个 jQuery 插件,使用警报显示 DOM 集中的项目数:

$.fn.showCount = function() { 
alert("Count = " + this.length); // "this" is a refernce to the jQuery object
}

或(完全相同):

// $.fn.extend is just a convenience method for extending the jQuery.fn object
// It's also the same as calling $.extend($.fn, { ... })

$.fn.extend( {
showCount: function() {
alert("Count = " + this.length);
}
});

所以当你打电话时:

$("a").showCount();

它会弹出一个警报,告诉您 <a> 的号码。文档中的标签。

编辑:

看到您的代码后,我认为我知道您的意思。

当使用 jQuery.extend() (不是 jQuery.fn.extend)时,您没有创建一个真正的插件。您只是创建一个全局函数或对象,与 jQuery 本身无关。

事实上,计时器插件可以这样编写,并且它会完成完全相同的事情:

var timerPlugin = {
global: [],
guid: 1,
dataKey: "jQuery.timer",
regex: /^([0-9]+(?:\.[0-9]*)?)\s*(.*s)?$/,
powers: {
// Yeah this is major overkill...
'ms': 1,
'cs': 10,
'ds': 100,
's': 1000,
'das': 10000,
'hs': 100000,
'ks': 1000000
},
timeParse: function(value) {
//...
}
// ...
};

然后(例如)您调用 timerPlugin.remove() 而不是 jQuery.timer.remove()

扩展 jQuery.fn 对象是为了允许在 jQuery 对象上调用您自己的函数。例如:$("a").myPlugin()

要记住的是 jQuery.extend() 与 jQuery 或 jQuery 插件无关。它只是 jQuery 库提供的一个实用函数。

关于jquery - 为什么要将 jquery.fn 对象传递给 jqueryobject,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1991395/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com