Alternative to jQuery#39;s .toggle() method that supports eventData?(替代支持 eventData 的 jQuery 的 .toggle() 方法?)
问题描述
.toggle()
方法的 jQuery 文档 声明:
提供 .toggle() 方法是为了方便.手动实现相同的行为相对简单,如果 .toggle() 内置的假设被证明是有限的,这可能是必要的.
The .toggle() method is provided for convenience. It is relatively straightforward to implement the same behavior by hand, and this can be necessary if the assumptions built into .toggle() prove limiting.
.toggle
中内置的假设已证明对我当前的任务有限制,但文档并未详细说明如何实现相同的行为.我需要将 eventData
传递给提供给 toggle()
的处理函数,但似乎只有 .bind()
会支持这一点,而不是.toggle()
.
The assumptions built into .toggle
have proven limiting for my current task, but the documentation doesn't elaborate on how to implement the same behavior. I need to pass eventData
to the handler functions provided to toggle()
, but it appears that only .bind()
will support this, not .toggle()
.
我的第一个倾向是使用对单个处理函数全局的标志来存储点击状态.换句话说,而不是:
My first inclination is to use a flag that's global to a single handler function to store the click state. In other words, rather than:
$('a').toggle(function() {
alert('odd number of clicks');
}, function() {
alert('even number of clicks');
});
这样做:
var clicks = true;
$('a').click(function() {
if (clicks) {
alert('odd number of clicks');
clicks = false;
} else {
alert('even number of clicks');
clicks = true;
}
});
我没有测试过后者,但我怀疑它会起作用.这是做这种事情的最好方法,还是我错过了更好的方法?
I haven't tested the latter, but I suspect it would work. Is this the best way to do something like this, or is there a better way that I'm missing?
推荐答案
似乎是一个合理的方法......我只是建议你使用 jQuery 的 数据存储 实用程序,而不是引入一个额外的变量(如果你想跟踪一大堆链接,这可能会让人头疼).所以根据你的例子:
Seems like a reasonable way to do it... I'd just suggest that you make use of jQuery's data storage utilities rather than introducing an extra variable (which could become a headache if you wanted to keep track of a whole bunch of links). So based of your example:
$('a').click(function() {
var clicks = $(this).data('clicks');
if (clicks) {
alert('odd number of clicks');
} else {
alert('even number of clicks');
}
$(this).data("clicks", !clicks);
});
这篇关于替代支持 eventData 的 jQuery 的 .toggle() 方法?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:替代支持 eventData 的 jQuery 的 .toggle() 方法?


基础教程推荐
- Javascript 在多个元素上单击事件侦听器并获取目标 2022-01-01
- WatchKit 支持 html 吗?有没有像 UIWebview 这样的控制器? 2022-01-01
- Node.js 有没有好的索引/搜索引擎? 2022-01-01
- 为什么我在 Vue.js 中得到 ERR_CONNECTION_TIMED_OUT? 2022-01-01
- 每次设置弹出窗口的焦点 2022-01-01
- jQuery File Upload - 如何识别所有文件何时上传 2022-01-01
- 如何使用sencha Touch2在单页中显示列表和其他标签 2022-01-01
- 如何在特定日期之前获取消息? 2022-01-01
- 如何使用 CSS 显示和隐藏 div? 2022-01-01
- 什么是不使用 jQuery 的经验技术原因? 2022-01-01