首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jQuery .change只适用于初审

jQuery .change只适用于初审
EN

Stack Overflow用户
提问于 2016-09-20 17:00:58
回答 4查看 840关注 0票数 0

我有一系列条件选择元素,它们使用.load从外部文件中插入动态内容。问题是,它只为第一个元素触发,任何后续的实例都不会导致任何操作。

我一开始是这样的:

代码语言:javascript
复制
jQuery(document).ready(function($) {


$('#autocad-level-1').change(function() {

    var cat_id = $(this).val();
    console.log('Category Selected');
    $('#autocad-level-2-container').load('http://website.dev/wp-content/themes/dmi/ajax/autocad-level-2.php?cat_id='+cat_id);

});

$('#autocad-level-2').change(function() {

    var p_id = $(this).val();
    console.log('Product Selected');
    $('#autocad-level-3-container').load('http://website.dev/wp-content/themes/dmi/ajax/autocad-level-3.php?p_id='+p_id);

});

});

研究表明,我应该使用.on作为事件处理程序,但我在这方面也没有成功。

代码语言:javascript
复制
jQuery(document).ready(function($) {

$('#autocad-level-1').on("change", "select", function() {

    var cat_id = $(this).val();
    console.log('Category Selected');
    $('#autocad-level-2-container').load('http://website.dev/wp-content/themes/dmi/ajax/autocad-level-2.php?cat_id='+cat_id);

});

$('#autocad-level-2').on("change", "select", function() {

    var p_id = $(this).val();
    console.log('Product Selected');
    $('#autocad-level-3-container').load('http://website.dev/wp-content/themes/dmi/ajax/autocad-level-3.php?p_id='+p_id);

});

});

这是我的HTML:

代码语言:javascript
复制
<div id="autocad-level-1-container">
    <select id="autocad-level-1" name="autocad-level-1">
      <option value="0">Select</option>
      <option value="1">Option 1</option>
      <option value="2">Option 2</option>
      <option value="3">Option 3</option>
      <option value="4">Option 4</option>
      ...
    </select>
</div>
<div id="autocad-level-2-container"></div>
<div id="autocad-level-3-container"></div>

我在这里做错什么了?我没有主意了。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2016-09-20 17:05:37

您需要侦听父元素的select,而不是select本身。

代码语言:javascript
复制
$('#autocad-level-2-container').on("change", "#autocad-level-2", function() { 
    /*** code here ***/
});
票数 1
EN

Stack Overflow用户

发布于 2016-09-20 17:04:11

尝试委托这些事件,如果您的.load更改了页面的html并替换了原始的选择框,那么绑定到它们的事件将被解除绑定。

如果你想做这样的事情:

代码语言:javascript
复制
$(document).on("change", "#autocad-level-2", function() { .... 

对于绑定在选择框上的所有更改事件也是如此。

票数 1
EN

Stack Overflow用户

发布于 2016-09-20 17:04:24

使用change,如下所示。

代码语言:javascript
复制
 $('#autocad-level-1').on('change',function() {

        var cat_id = $(this).val();
        console.log('Category Selected');
        $('#autocad-level-2-container').load('http://website.dev/wp-content/themes/dmi/ajax/autocad-level-2.php?cat_id='+cat_id);

    });
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39599885

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档