JavaScript实现多选框输入
P粉502608799
P粉502608799 2023-09-06 09:26:47
0
1
526
<p>当我点击选择时,会弹出一个框,我们可以选择多个选项,包括父级和子级。当选项被选中后,立即在输入框中显示ID号码。当我们点击确定时,框将被隐藏。我希望每个框都在输入框中单独完成。这是我的HTML:</p> <pre class="brush:php;toolbar:false;"><p>当我点击选择时,会弹出一个框,我们可以选择多个选项,包括父级和子级。当选项被选中后,立即在输入框中显示ID号码。当我们点击确定时,框将被隐藏。我希望每个框都在输入框中单独完成。这是我的HTML:</p> <pre><code><button class="btn-select">选择一个...</button> <div class="box" style="display:none"> <input type="checkbox" class="checkbox" value="1">复选框1 <input type="checkbox" class="checkbox" value="2">复选框2 <input type="text" class="input input-1" value=""> <button class="btn-ok">确定</button> </div> <button class="btn-select">选择两个(父级/子级)...</button> <div class="box" style="display:none"> <ul class="father"> <li> <input type="checkbox" class="checkbox" value="1">部分1 <ul class="children"> <li><input type="checkbox" class="checkbox" value="5">复选框5</li> </ul></li> <li> <input type="checkbox" class="checkbox" value="2">部分2 <ul class="children"> <li><input type="checkbox" class="checkbox" value="7">复选框7</li> <li><input type="checkbox" class="checkbox" value="8">复选框8</li> </ul></li></ul> <input type="text" class="input input-2" value=""> <button class="btn-ok">确定</button> </div> 。 ...选择三个... ..选择四个.. .. .</pre> <p>这是我的JS(子级和父级):</p>
handleChildren = function() {
    var $checkbox = $(this);
    var $checkboxChildren = $checkbox.parent();
    $checkboxChildren.each(函数() {
      if ($checkbox.is(":checked")) {
        $(this).prop(“已检查”, “已检查”);
      } 别的 {
        $(this).removeProp(“选中”);
      }
    });
};
句柄父母 = 函数(当前){
    var $parent = $(current).closest(".children").closest("li").find(>> input[type=checkbox]");
    if ($parent.parent().find(".children input[type=checkbox]:checked").length > 0) {
      $parent.prop(“已检查”, “已检查”);
    } 别的 {
      $parent.removeProp(“选中”);
    }
    处理父母($父母);
}
$(“ul.father”).find(“input[type=checkbox]”).each(function() {
    $(input).on(“点击”,handleChildren);
    $(input).on(“点击”, function() {
        处理父母(这个);
    });
});</pre>
<p>这是我的JS:</p>
$(document).on('click', '.btn-ok', function(){
    $('.box').hide()
});
$(document).on('点击', '.btn-select', function(){
    $('.box').hide()
    $(this).next().show();
});
$(“.checkbox”).change(function() {
    var 文本 = "";
    $(".checkbox:checked").each(function() {
        文本 += $(this).val() + ",";
    });
    文本 = text.substring(0, text.length - 1);
    $(this).next().val(文本);
});</pre>
<p>现在控制台显示了一个错误:</p>
<pre class="brush:php;toolbar:false;">未捕获的内部错误:递归过多
    最接近的文件:///var/www/html/jquey.js:1</pre></p>            
P粉502608799
P粉502608799

全部回复(1)
P粉141035089

您的handleParents无条件地调用自身。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板