是否有办法为页面上的不同元素执行相同的代码?

$('.class1').click(function() {
   some_function();
});

$('.class2').click(function() {
   some_function();
});

相反,你可以这样做:

$('.class1').$('.class2').click(function() {
   some_function();
});

谢谢


当前回答

$('.class1, .class2').click(some_function);

确保你输入了一个像$('的空格。Class1,空格。class2')否则不行。

其他回答

$('.class1, .class2').on('click', some_function);

Or:

$('.class1').add('.class2').on('click', some_function);

这也适用于现有的对象:

const $class1 = $('.class1');
const $class2 = $('.class2');
$class1.add($class2).on('click', some_function);

只需使用$('。Myclass1, .myclass2, .myclass3')用于多个选择器。同样,你也不需要lambda函数来将现有的函数绑定到click事件。

如果你有或想保持你的元素作为变量(jQuery对象),你也可以循环它们:

var $class1 = $('.class1');
var $class2 = $('.class2');

$([$class1,$class2]).each(function() {
    $(this).on('click', function(e) {
        some_function();
    });
});

我们也可以像下面这样编码,我在这里使用了模糊事件。

$("#proprice, #proqty").blur(function(){
      var price=$("#proprice").val();
      var qty=$("#proqty").val();
      if(price != '' || qty != '')
      {
          $("#totalprice").val(qty*price);
      }
  });
$('.class1, .class2').click(some_function);

确保你输入了一个像$('的空格。Class1,空格。class2')否则不行。