单击添加按钮后,添加另一个具有输入框值的单选按钮

时间:2020-11-12 07:05:34

标签: javascript html jquery

伙计们,我有一个要在其中显示多个单选按钮的表单。因此默认情况下,我正在显示一个带有文本的单选按钮,并给选项指定为Addother按钮。因此用户可以按添加添加多个单选按钮onclick他们的要求。

这就是我尝试过的。

答案部分:
            <div class="custom-control custom-radio" id="add_other">
              <div id="container0">
                <input type="radio" class="custom-control-input" id="defaultUnchecked" name="defaultExampleRadios">
                <input type="search" name="" value="">
              </div>
            </div>
            <div class="custom-control custom-radio" >
              <input type="radio" class="custom-control-input" id="defaultUnchecked" name="defaultExampleRadios">
              <input type="search" name="" value="">
              <button class="remove" onclick="removeDiv(this);">X</button>
            </div>
            <div class="custom-control custom-radio">
             <input type="radio" class="custom-control-input" id="defaultUnchecked" name="defaultExampleRadios">
             <input type="search" name="" value="">
             <button class="remove" onclick="removeDiv(this);">X</button>
           </div>
           <div class="custom-control custom-radio">
             <input type="radio" class="custom-control-input" id="defaultUnchecked" name="defaultExampleRadios">
             <input type="search" name="" value="">
             <button class="remove" onclick="removeDiv(this);">X</button>
           </div>
           <div class="custom-control copy-radio" onclick="addoptions()">
              <label class="add_option" id="add_othe1r">Add More</label>
            </div>


        </div>

脚本代码:

var index = 3;

  function addoptions() {
    $('#add_other').append(`<div id="container${index}" >` + '<input type="radio" class="custom-control-input" name="defaultExampleRadios"/ >'  + `<input type="search" name="text"/>` +  "</div>");
    index ++;
  }
function removeDiv(btn){
    ((btn.parentNode).parentNode).removeChild(btn.parentNode);
  }

2 个答案:

答案 0 :(得分:1)

您将ID add_other设置为“添加选项”按钮容器。您需要删除该ID并将其重置为第一个div容器

var index = 1;

function addoptions() {
  $('#add_other').append(`<div id="container${index}" >` + '<input type="radio" class="custom-control-input" name="defaultExampleRadios"/>' + `<input type="search" name="text" onsearch="deleteRadio(${index})"/>` + "</div>");
  index ++;
}

function deleteRadio(ind) {
  $(`#container${ind}`).remove();
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.1/jquery.min.js"></script>
<div id="hidden_radio_buttons" class="radio_buttons" style="margin:10px;">
  <!-- Default unchecked -->
  <div class="custom-control custom-radio" id="add_other">
    <div id="container0">
      <input type="radio" class="custom-control-input" id="defaultUnchecked" name="defaultExampleRadios">
      <input type="search" name="" value="" placeholder="option 1" onsearch="deleteRadio(0)">
    </div>
  </div>

  <!-- Default unchecked -->
  <div class="custom-control copy-radio" onclick="addoptions()">
    <input type="radio" class="custom-control-input" name="defaultExampleRadios">
    <label class="add_option" id="add_othe1r">Add Option</label>
  </div>
</div>

答案 1 :(得分:1)

您需要在“ add_other”容器的ID内设置3个新容器。

function addoptions() {
  $('#add_other').append('<div>' + '<input type="radio" class="custom-control-input" name="defaultExampleRadios">' + '<input type="search" name="" value="">' + '<button class="remove" onclick="removeDiv(this);">X</button>' + "</div>");
}

function removeDiv(btn) {
  ((btn.parentNode).parentNode).removeChild(btn.parentNode);
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.1/jquery.min.js"></script>
<div class="custom-control custom-radio" id="add_other">
  <div id="container0">
    <input type="radio" class="custom-control-input" name="defaultExampleRadios">
    <input type="search" name="" value="">
  </div>
  <div class="custom-control custom-radio">
    <input type="radio" class="custom-control-input"  name="defaultExampleRadios">
    <input type="search" name="" value="">
    <button class="remove" onclick="removeDiv(this);">X</button>
  </div>
  <div class="custom-control custom-radio">
    <input type="radio" class="custom-control-input" name="defaultExampleRadios">
    <input type="search" name="" value="">
    <button class="remove" onclick="removeDiv(this);">X</button>
  </div>
  <div class="custom-control custom-radio">
    <input type="radio" class="custom-control-input" name="defaultExampleRadios">
    <input type="search" name="" value="">
    <button class="remove" onclick="removeDiv(this);">X</button>
  </div>

</div>
<div class="custom-control copy-radio" onclick="addoptions()">
  <label class="add_option" id="add_othe1r">Add More</label>
</div>