javascript - 如何使 <li> 可从返回动态 html 的 ajax 搜索结果中单击?

标签 javascript jquery ajax

当用户开始在文本字段中输入内容时,我使用 ajax 来搜索数据库。结果显示在无序列表中。我希望他们能够单击列表项,并且该项目必须出现在文本框中。我可以进行搜索并显示列表,但我在点击 li 部分时遇到了困难。

HTML:

<div class="form-group">
  <input type="text" name="name" autocomplete="off" id="name">
  <div class="result"></div>
</div>
<div style="display:none" class="loader">
  <img src="../build/css/ajax-loader.gif" />
</div>

JS:

$(document).ready(function() {
  $("input").keyup(function() {
    $(".loader").show();
    var input = $(this).val();
    if (input.length > 3) {
      $.ajax({
        type: 'POST',
        url: 'insert-ajax.php',
        data: {
          name: input
        },
        success: function(data) {

          if (!data.error) {
            $(".result").html(data);
            $(".loader").hide();
          }
        }

      });
    }

    if (input.length < 1) {
      $(".loader").hide();
      $(".result").html("");
    }
  });

  $(".result li").click(function() {
    alert($(this).data());
  });

});

最佳答案

您需要使用event delegation为此。

由于您的结果是根据搜索查询添加/删除的动态元素,因此您无法在它们上绑定(bind)点击处理程序,而应该将其绑定(bind)到其父级。

这样做的结果是,结果中的任何元素(因此不仅仅是 <li> 元素)在单击时都会触发此回调。这意味着您必须过滤掉不想触发点击的元素。

jQuery 的 on 方法提供了一种简洁的方法来进行委托(delegate)和过滤:

// the callback gets called whenever a `li` element within `.result` is clicked
$(".result").on( "click", "li", function() {
  console.log($(this).text());
});

关于javascript - 如何使 <li> 可从返回动态 html 的 ajax 搜索结果中单击?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42656449/

相关文章:

javascript - 在 AngularJS 中的 ng-if 或 ng-show 内部进行迭代

javascript - for 循环和 if 语句

javascript - 通过 Javascript 停止/启动 SVG 旋转

javascript - jQuery 列表上的 TouchSwipe

jquery - 目前最好的 Ajax 历史记录和书签插件

javascript - 如何在 Javascript 中将字符串转换为脊柱大小写?

javascript - jQuery - 如何使输入值 ("email"、 "password")在失焦时重新出现?

javascript - 我可以使用 p5js 在同一页面上创建多个 Canvas 元素吗

ajax - 完整的 ajax 网站和 SEO

jquery - Rails 嵌套资源 - 使用 form_for 部分创建和编辑 2 个级别