测试开发vue — watch监听data的数据变化

Posted 把苹果咬哭

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了测试开发vue — watch监听data的数据变化相关的知识,希望对你有一定的参考价值。

上一篇里提到了用elementUI的select实现了个远程搜索的功能,最终效果是这样的。

但是继续开发的时候,又遇到了一个新的问题,跟上面的功能有关。

先看下远程搜索的操作,与data里的数据关系。

  • 当输入“张”进行搜索,看到的下拉列表里展示的结果都是存放在data的options: []
  • 当我选择了一个,比如“张三”,因为select框做了绑定v-model="user_value",所以此时user_value有了对应人员的值,存放的是id。
  • 最后的ad_real_name是后加的,因为我有一个接口要改动,本来只要传id的,现在还要多传入个收货人的姓名。

新问题

之前只传id,做起来就很简单,因为绑定了user_value了,直接用就好了。
但是现在我需要把ad_real_name也传过去,问题是我如何在user_value有值(id)的时候,把id对应人的姓名赋给ad_real_named

解决

我先试着同一个事件里面能不能调用2个方法,结果不太行。

再后来我就想到监听了,当点击了人员后,user_value此时被赋值,如果我监听这个字段,当有值的时候,去把人名赋给ad_real_name即可。

接下来就是代码实现了:

1. 先把姓名的值,也加到options里

这个options是个列表,里面的元素是一个个对象{},对象里就是key-value。之前只放了{value:"", label: ""},现在我要把ad_real_name也放进去,变成
{value:"", label: "", ad_real_name: ""}

2. 在监听里增加for循环和判断

当选择了人员之后,此时for循环这个options,遍历每一个对象。然后判断当对象里的value=选定的user_value,就把这个对象中的"ad_real_name"对应值赋给data里的字段ad_real_name

为了快速验证效果,在console里加了log打印。最终的代码是:

watch: {
    user_value:function() {
        for (let i=0; i<this.options.length; i++) {
            if (this.options[i][\'value\'] === this.user_value) {
                this.ad_real_name = this.options[i][\'ad_real_name\'];
                console.log("打印this.ad_real_name", this.ad_real_name)
            }
        }
    }
},
  • user_value:表示我要监听这个字段。
  • function():这里写监听到变化后,要做的处理。

F12打开控制台,目标达成。

或许还有别的更快捷的方法,但是毕竟我是前端小白,快速解决问题为首要,如果大佬们有更好的写法建议,还请不吝赐教。

以上是关于测试开发vue — watch监听data的数据变化的主要内容,如果未能解决你的问题,请参考以下文章

Vue: computed和watch

vue计算属性与watch监听

vue 中的computed 和 watch 监听

vue怎么让页面挂载完成之后开始监听data的变化

vue中watch监听值或者form对象以及路由的变化

vue 中watch监听对象,求大神解答