在 jQuery 中将 2 个函数合并为一个
Combine 2 functions to one in jQuery
我有一个小的jquery函数,可以根据选择的内容显示和隐藏,我在同一页面上运行了其中的2个,但每个都有自己的数据附加到选择中,我想知道如何整理下面的函数 - 我会通过使用.attr函数找出id然后为每件事使用某种方式来为 #rearq/#rearw 创建一个变量吗?
$('#rearw li a').click(function(ev){
ev.preventDefault();
var id = $(this).data('id');
$('#rearw li a').not($(this).toggleClass('selected')).removeClass('selected');
$('#rearw-tints li').not($('#'+id).toggleClass('shown')).removeClass('shown');
});
$('#rearq li a').click(function(ev){
ev.preventDefault();
var id = $(this).data('id');
$('#rearq li a').not($(this).toggleClass('selected')).removeClass('selected');
$('#rearq-tints li').not($('#'+id).toggleClass('shown')).removeClass('shown');
});
这是我到目前为止所拥有的:
var control = $('.control ul').attr('id'); // Get the id e.g #rearw / #rearq
$(control).each(function (index) {
$(control + ' li a').click(function (ev) {
ev.preventDefault();
var id = $(this).data('id');
$(control + ' li a').not($(this).toggleClass('selected')).removeClass('selected');
$(control + '-tints li').not($('#' + id).toggleClass('shown')).removeClass('shown');
});
}
任何帮助/指示非常感谢!
只需更改您的代码:
var control = $('.control ul').attr('id');
对此:
var control = '#' + $('.control ul').attr('id');
此外,您不必在此处使用 each 循环,因为 ID 在 DOM 中应该是唯一的。 因此,您可以删除它并使用如下代码:
$(control + ' li a').click(function (ev) {
ev.preventDefault();
var id = $(this).data('id');
$(control + ' li a').not($(this).toggleClass('selected')).removeClass('selected');
$(control + '-tints li').not($('#' + id).toggleClass('shown')).removeClass('shown');
});
更新
您的代码
var control = $('.control ul').attr('id');
只会给你一个ID,因此你可以这样做,同样的逻辑,但修改了一点:
$('.control ul').each(function () {
var control = '#' + this.id;
$(control + ' li a').click(function (ev) {
ev.preventDefault();
var id = $(this).data('id');
$(control + ' li a').not($(this).toggleClass('selected')).removeClass('selected');
$(control + '-tints li').not($('#' + id).toggleClass('shown')).removeClass('shown');
});
});
你需要id选择器#
和id(control)
改变
$(control)
自
$('#'+control);
$('#rearw li a, #rearq li a').click(function(ev){
ev.preventDefault();
var id = $(this).data('id'),
parent = $(this).closest('ul'), // assuming #rearw and #rearq are <ul> elements
parentId = parent.attr('id'); // get 'rearw' or 'rearq'
parent.find('a').not($(this).toggleClass('selected')).removeClass('selected');
$('#' + parentId +'-tints li').not($('#'+id).toggleClass('shown')).removeClass('shown');
});
大致如下
:
$('#rearw li a, #rearq li a').click(function(ev){
ev.preventDefault();
var id = $(this).attr('id');
$(this).closest('#rearw, #rearq').find('li a').not($(this).toggleClass('selected')).removeClass('selected');
$(id + '-tints li').not($('#'+id).toggleClass('shown')).removeClass('shown');
});
不确定我是否在转换时犯了错误,但这个想法:)
相关文章:
- 我可以在json对象中添加一个函数吗
- 如何在JQuery函数中定义一个值,然后调用另一个函数并使用该值
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在另一个函数中使用变量this
- 在另一个函数成功结束后调用该函数
- mongoose.connect undefined不是一个函数
- 监听器必须是一个函数
- 使用JS函数来使用另一个函数的语法?node.js
- 如何取消object.prototypes javascript的一个函数
- 从Chrome扩展名中的popup.html文件在background.js文件中运行一个函数
- 嵌套到另一个函数中的Fancybox函数;不起作用
- 如何在javascript中使用不止一个函数
- jQuery-在页面加载时执行一个函数
- jquery UI draggable:UI.children不是一个函数
- jQuery Mobile Undefined不是一个函数
- 如何在php中创建一个函数,该函数与文本区域一起工作,通过输入类似[color:red]的内容来打印具有等效颜色的文本
- javascript函数将数据添加到屏幕,但随后被另一个函数覆盖
- JS异常:animate不是一个函数
- 如何将一个函数附加到一个不存在的元素上
- JavaScript/jQuery-添加添加和删除类与下一个函数之间的延迟