JavaScript,在动态添加的元素上启用查询选择器

标签 javascript jquery html

我在正文中有 DIV 元素,我复制该元素以向数据库添加更多元素,但是当我执行如下所示的脚本时:

$(document).ready(function(){

$(document.body).on('change','.jobType',function(){
    var value = this.options[this.selectedIndex].value;
    select = this;
    $.ajax({
        url: 'getpart',
        dataType: "json",
        type: 'post',
        data: {
            part_id : value,
        },
        success: function( data ) {
            wrapper = select.closest('.wrapper');
            console.log(v, select);
            inputPrice = wrapper.querySelector('.jobPrice')
            console.log(inputPrice, data.Part.price);
            inputPrice.value = data.Part.price;
        }
    });
});
});

var wrapper 是 null 因为它是动态添加到 DOM 的,有没有办法在新添加的元素上使用 document.querySelector()

最佳答案

我已将 jquery 语句添加到您现有的代码中。如果你有 jQuery,你可以使用它。

变化:

1) var select = $(this);

2) var value = select.val();

3) var wrapper = select.closest('.wrapper');

4) var inputPrice = wrapper.find('.jobPrice')

$(document).ready(function(){

  $(document.body).on('change','.jobType',function(){
    var select = $(this);
    var value = select.val();
    $.ajax({
        url: 'getpart',
        dataType: "json",
        type: 'post',
        data: {
            part_id : value,
        },
        success: function( data ) {
            var wrapper = select.closest('.wrapper');
            console.log(select);
            var inputPrice = wrapper.find('.jobPrice')
            console.log(inputPrice, data.Part.price);
            inputPrice.val(data.Part.price);
        }
    });
  });
});

关于JavaScript,在动态添加的元素上启用查询选择器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32497395/

相关文章:

html - 楔形菜单

javascript - 如何通过 JavaScript 检测事件?

javascript - 如何在 Angular 中显示/隐藏按钮

javascript - 使用表格数据填写表格

vim 中的 Javascript 语法高亮显示

javascript - 如何在没有大量代码的情况下操作单个输入字段值

jquery - 如何向此 jQuery 函数添加 'click' 函数?

javascript - 所选值不起作用。如何使用kendo multiselect(MVVM)获取所选元素的值?

javascript - AngularJS : Want to disable the link when it clicked once

javascript - 从 ASP.NET View 调用 C# 函数