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

本文小编为大家详细介绍“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对象的值导致没有更新到数据中怎么解决
文章来源:http://scyanting.com/article/pshjid.html