当前位置: 代码网 > it编程>编程语言>Javascript > 解决vue页面注入js修改input值问题

解决vue页面注入js修改input值问题

2024年05月18日 Javascript 我要评论
解决vue页面注入js修改input值一般会直接这样写let zz = document.getelementsbyclassname('el-input__inner')[0];zz.value =

解决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); //可直接获取绑定数组修改后的值
  },

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com