解决vue页面注入js修改input值
一般会直接这样写
let zz = document.getelementsbyclassname('el-input__inner')[0]; zz.value = 'test';
但在某些前端框架,例如vue之类的,vue的input弄个双向绑定啥的,此时我们用原生的js企图去控制输入框的值就会出现无效的情况(明明input上有数字或者字符但是点击按钮就是说你没填内容)。
只有当接收到键盘的按键(随便哪个键盘的按键消息),才会触发input和change事件,进而把输入框中的value赋值给预设的相关变量,到这一步才算走完整个设置value的过程。
所以如果想给这类加料的输入框或者选择框用原生js赋值,设置vlaue属性过后就必须手动触发一下input或change事件。
下面是例子
var zz = document.getelementsbyclassname('el-input__inner')[0] zz.value = 'test' var event = document.createevent('event'); event.initevent("input", true, true);//如果是select选择框把"input"改成"change" event.eventtype = 'message' zz.dispatchevent(event)
vue循环input框且对应修改值
效果:
<li> <span>实体名称</span>: <span>{{ newknowname }}</span> </li> <li> <span>实体标签</span>: <span> {{ newknowlabel }}</span> </li> <li> <span>实体属性</span>: <ul> <li v-for="(item, index) in newknowpros" :key="index"> <span>{{ item.key }}</span> : <span><input type="text" v-model="item.value"/></span> </li> </ul> </li>
//入库 mergeentity() { console.log(this.newknowpros); //可直接获取绑定数组修改后的值 },
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
发表评论