javascript - 如何在按钮单击时添加输入字段

标签 javascript jquery

function add() {
  var new_chq_no = parseInt($('#total_chq').val()) + 1;
  var new_input = "<input type='text' id='new_" + new_chq_no + "'>";
  $('#new_chq').html(new_input);
}

function remove() {
  var last_chq_no = $('#total_chq').val();
  if (last_chq_no > 1) {
    $('#new_' + last_chq_no).append('');
    $('#total_chq').val(last_chq_no - 1);
  }
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type="text">
<button onclick="add()">Add</button>
<button onclick="remove()">remove</button>
<div id="new_chq"></div>
<input type="hidden" value="1" id="total_chq">

它一次添加输入字段,第二次单击它不添加任何内容,并且删除按钮不起作用

最佳答案

<强> Working fiddle

追加元素时必须使用 .append() 而不是 .html() :

$('#new_chq').append(new_input);

最好将事件附加到 JS 代码中,如下所示:

$('.add').on('click', add);
$('.remove').on('click', remove);

注意1:不要忘记增加计数器#total_chq:

$('#total_chq').val(new_chq_no);

注意 2:如果要删除元素,则必须使用 .remove()

$('.add').on('click', add);
$('.remove').on('click', remove);

function add() {
  var new_chq_no = parseInt($('#total_chq').val()) + 1;
  var new_input = "<input type='text' id='new_" + new_chq_no + "'>";

  $('#new_chq').append(new_input);

  $('#total_chq').val(new_chq_no);
}

function remove() {
  var last_chq_no = $('#total_chq').val();

  if (last_chq_no > 1) {
    $('#new_' + last_chq_no).remove();
    $('#total_chq').val(last_chq_no - 1);
  }
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type="text">
<button class="add">Add</button>
<button class="remove">remove</button>
<div id="new_chq"></div>
<input type="hidden" value="1" id="total_chq">

关于javascript - 如何在按钮单击时添加输入字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50746868/

相关文章:

javascript - 切换 div 在特定时间滑动

javascript - 如果移除了一个 DOM 元素,它的监听器是否也会从内存中移除?

javascript - 使用 JS 实现 cookie 来识别回访者

javascript - 单击 anchor 链接时如何在转发器中查找文本框值

javascript - ListView 中的 Observable 错误地绑定(bind)了元素

javascript - React 不渲染组件

javascript - 我的 JavaScript 图片库 slider 的右侧 slider 无法正常工作,而左侧的 slider 可以正常工作

javascript - 一步定义和调用函数

javascript - 使用 AJAX + jQuery 和输入元素 ID 发布文件

javascript - 箭头键导航不适用于 li 元素