6

是否有 jQuery 1.7+ 的 jQuery livequery 插件的等价物?

我正在尝试动态绑定事件,读取 DOM 元素应基于 data-* 元素绑定的事件。

<a href="#" class="js-test" data-events="click">Test 1</a>
<a href="#" class="js-test" data-events="mouseover">Test 2</a>
 .. etc ..

我想将所有元素与类绑定,.js-test但仅限于其data-events属性中列出的事件。

jQuery.on/live/bind/delegate 都要求将事件作为参数传入。

这适用于页面上存在的 DOM 元素 when document.ready,但是当我更新 DOM(AJAX、JS 等)时,我希望任何具有类.js-test的新元素也能够绑定其事件。

livequery 插件(它是旧的,从 jQuery 1.3 时代开始)似乎允许这样做,因为它简单地需要一个选择器和一个函数来针对与选择器匹配的任何东西运行。

4

1 回答 1

14

jQuery 1.7 开始,on方法取代了 live 方法。虽然它没有像您描述的那样传递或匹配选择器的简单方法,但可以通过传入动态值data-events代替事件类型来完成此操作,只要数据事件值与该事件匹配.

然而,由于传递给 on 方法的事件参数的参数——第一个参数——是从每个 data-events 属性中获取的,从匹配元素集中的每个元素中,我们必须遍历匹配元素的集合,以便我们分别访问每个元素的单独 data-events 属性值:

$('.js-test').each(function() { 
    $(this).on( $(this).attr("data-events"), function() {

        // event pulled from data-events attribute           
        alert("hello - this event was triggered by the " + $(this).attr("data-events") + " action.");

    });
});

我希望所有事件都映射到同一个函数,但有不同的事件触发对不同 DOM 元素的函数调用。

由于您希望将所有事件映射到单个函数,因此此解决方案可以满足您的特定要求并解决您的问题。

但是,如果您的需求发生变化并且您发现需要映射一组函数事件以匹配每种事件类型,这应该可以帮助您开始:

var eventFnArray = [];
eventFnArray["click"] = function() { 
    alert("click event fired - do xyz here");
    // do xyz
};
eventFnArray["mouseover"] = function() { 
    alert("mouseover fired - do abc here"); 
    // do abc
};

$('.js-test').each( (function(fn) { 

   return function() {   
     $(this).on( $(this).attr("data-events"), function() {

        alert("hello - this is the " + $(this).attr("data-events") + " event");

        // delegate to the correct event handler based on the event type
        fn[ $(this).attr("data-events") ]();

     });
   }
})(eventFnArray)); // pass function array into closure

更新:

这已经过测试,并且确实适用于添加到 div#container 的新元素。问题在于on方法的运作方式。The delegating nature of ononly works if the parent element is included in the selector, and only if a selector is passed into the second parameter, which filters the target elements by data-events attribute:

HTML:

<div id="container">
    <a href="#" class="js-test" data-events="click">Test 1</a>
    <a href="#" class="js-test" data-events="mouseover">Test 2</a>
</div>

JavaScript:

$(document).ready(function() {
  $('.js-test').each(function() { 
      var _that = this;
      alert($(_that).attr("data-events"));

      $(this).parent().on(
          $(_that).attr("data-events"), 
              '.js-test[data-events="'+ $(_that).attr("data-events") +'"]', 
              function() {

                  // event pulled from data-events attribute           
                  alert("hello - this event was triggered by the " + $(_that).attr("data-events") + " action.");
              }
          );
      }
  ); 
});

此外,使用以下 jQuery 将项目添加到容器以对其进行测试:

$('#container')
    .append("<a href='#' class='js-test' data-events='mouseover'>Test 3</a>");

试试看:

这是一个演示测试和工作功能的jsfiddle

于 2012-05-26T23:27:50.750 回答