189 8069 5689

VUE直接通过JS修改html对象的值导致没有更新到数据中怎么办

小编给大家分享一下VUE直接通过JS修改html对象的值导致没有更新到数据中怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站设计、做网站、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的于田网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

业务场景

我们在使用vue 编写 代码时,我们有一个 多行文本框控件,希望在页面点击一个按钮 在 文本框焦点位置插入一个 {pk}的数据。

发现插入 这个数据后,这个数据并没有同步到 数据中,但是直接通过键盘输入,就可以改变数据。

原因分析

在通过 JS 修改控件的value 数据后,并没有触发到数据更新。

解决办法

Vue.component('rx-textarea', {
 props: {
  value:[String,Number],
  cols: {
   type: Number,
   default: 60
  },
  rows: {
   type: Number,
   default: 4
  }
 },
 data() {
  return {
   curVal:this.value
  }
 },
 template: "
",  methods:{   change:function(e){    this.$emit('input', e.target.value);   },   focus:function(e){    this.$emit('myfocus', e);   }  },  watch: {   curVal: function (val, oldVal){    this.$emit('input', this.curVal);   },   value :function(val,oldVal){    if(val!=oldVal){     this.curVal=this.value;    }   }  } })

当文本框获取焦点时,我们发布一个 myfocus 控件,我们在使用这个控件的时候。

编写一个 getTextarea 的方法。

var curTextarea=null;
function getTextarea(e){
 curTextarea= e.target;
}

这里将文本框控件,抛出来,我们可以通过 js代码修改这个控件的value。

function insertPK(){
 $.insertText(curTextarea,"{pk}")
}

通过这个代码我们往焦点处插入我们的代码。

当文本框失去焦点时,将当前控件的值作为 input 事件进行发布,从而实现了数据的同步。

以上是“VUE直接通过JS修改html对象的值导致没有更新到数据中怎么办”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


标题名称:VUE直接通过JS修改html对象的值导致没有更新到数据中怎么办
URL标题:http://gzruizhi.cn/article/ieidhe.html

其他资讯