jQuery одно и то же событие для нескольких элементов - PullRequest
399 голосов
/ 21 августа 2009

Есть ли способ выполнить один и тот же код для разных элементов на странице?

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

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

вместо этого сделать что-то вроде:

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

Спасибо

Ответы [ 10 ]

794 голосов
/ 21 августа 2009
$('.class1, .class2').on('click', some_function);

Или:

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

Это также работает с существующими объектами:

const $class1 = $('.class1');
const $class2 = $('.class2');
$class1.add($class2).on('click', some_function);
91 голосов
/ 11 июля 2014

Я обычно использую on вместо click. Это позволяет мне добавлять больше слушателей событий к определенной функции.

$(document).on("click touchend", ".class1, .class2, .class3", function () {
     //do stuff
});

Надеюсь, это поможет!

36 голосов
/ 25 августа 2011
$('.class1, .class2').click(some_function);

Убедитесь, что вы поставили пробел, такой как $ ('. Class1, пробел здесь.class2'), иначе он не будет работать.

15 голосов
/ 21 августа 2009

Просто используйте $('.myclass1, .myclass2, .myclass3') для нескольких селекторов. Кроме того, вам не нужны лямбда-функции для привязки существующей функции к событию click.

9 голосов
/ 07 апреля 2015

Другой вариант, если предположить, что ваши элементы хранятся как переменные (что часто является хорошей идеей, если вы обращаетесь к ним несколько раз в теле функции):

function disableMinHeight() {
    var $html = $("html");
    var $body = $("body");
    var $slideout = $("#slideout");

    $html.add($body).add($slideout).css("min-height", 0);
};

Использует преимущества цепочки jQuery и позволяет использовать ссылки.

2 голосов
/ 21 марта 2019

Если вы хотите или хотите сохранить свои элементы как переменные (объекты jQuery), вы также можете зациклить их:

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

$([$class1,$class2]).each(function() {
    $(this).on('click', function(e) {
        some_function();
    });
});
2 голосов
/ 26 сентября 2017

Добавьте список классов через запятую, например:

jQuery(document).ready(function($) {

$('.class, .id').click(function() { 

//  Your code

    }

});
1 голос
/ 28 декабря 2016

Мы также можем кодировать, как показано ниже, здесь я использовал событие размытия.

$("#proprice, #proqty").blur(function(){
      var price=$("#proprice").val();
      var qty=$("#proqty").val();
      if(price != '' || qty != '')
      {
          $("#totalprice").val(qty*price);
      }
  });
0 голосов
/ 24 июля 2017

В дополнение к превосходным примерам и ответам, приведенным выше, вы также можете выполнить «поиск» для двух разных элементов, используя их классы. Например:

<div class="parent">
<div class="child1">Hello</div>
<div class="child2">World</div>
</div>

<script>
var x = jQuery('.parent').find('.child1, .child2').text();
console.log(x);
</script>

Это должно вывести "HelloWorld".

0 голосов
/ 01 декабря 2016

У меня есть ссылка на объект, содержащий множество полей ввода, который должен обрабатываться одним и тем же событием. Поэтому я просто использую find () , чтобы получить все внутренние объекты, которые должны иметь событие

var form = $('<form></form>');
// ... apending several input fields

form.find('input').on('change', onInputChange);

Если ваши объекты находятся на один уровень ниже по ссылке children () вместо find () может использоваться метод.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...