js—input框中输入数字,动态生成内容的方法

时间:2022-01-04 11:11:08

项目中需要在前端实现:

  1. 用户输入数字n,动态生成n个元素,删除n,自动清空n个元素(如图一);
  2. 用户输入数字n,失焦生成n个元素,再聚焦修改n,自动清空n个元素(如图二);

图一:

js—input框中输入数字,动态生成内容的方法

图二:

js—input框中输入数字,动态生成内容的方法

需求一实现方式:

 <input type="number" placeholder="请输入图片数量" id="img_num" name="img_num" />张

 <li id="img_upload"></li>

 <script>
$('#img_num').bind('input propertychange',function() {
$("#img_upload").empty();
var text = $('input[name="img_num"]').val();
//console.log(text);
for (let i =1;i<=text;++i){
$("<li id='preview_"+i+"'><b>*</b> <span>图片"
+i+
": </span><span ><input name='img[]' type='file' id='imgFile_"+i+
"' accept='image/*' /></span> </li>").appendTo($('#img_upload'));
}
});
</script>

需求二实现方式:

 <input type="number" placeholder="请输入图片数量" id="img_num" name="img_num" />张
<li id="img_upload"></li>
<script> // 聚焦清空
$('#img_num').focus(function(){
$('#img_upload').empty();
}) // 失焦写入;动态生成input上传框 $('#img_num').blur(function() {
$("#img_upload").empty();
var text = $('input[name="img_num"]').val();
console.log(text);
for (let i =1;i<=text;++i){
$("<li id='preview_"+i+"'><b>*</b> <span>图片"
+i+
": </span><span ><input name='img[]' type='file' id='imgFile_"+i+
"' accept='image/*' /></span> </li>").appendTo($('#img_upload'));
}
});
</script>

针对关键点总结:

事件方法名  用法 释义
bind
el.bind(“oninput,propertychange”,function(){})①
绑定元素,监听元素 
focus
el.blur(function(){})
input框聚焦时执行
blur
el.blur(function(){})
input框失焦时执行

备注:

①:bind中 oninput 和 propertychange,都是事件对象,是在值改变时立即触发;只是后者是用以替代oninput在IE9以下的不兼容性;另:onchange是在值改变后失去焦点才触发,并且可以用在非输入框中,如:select等

相关链接:https://www.cnblogs.com/LHYwin/p/6136256.html.bind('input propertychange'

propertychange