• 【测试开发】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打开控制台,目标达成。

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

    -----------------2021-05-25------------更-------------
    往后开发的时候发现还是有些问题,F12看了下,传递到接口的值ad_real_name还是null。

    但是控制台输出这个字段又是有值的。于是我猜想,是不是事件触发的太快了,也就是说ad_real_name其实还没来得及赋上值,就发送后端请求了。

    于是,我处理了下后端发送请求的方法,加了个延迟500ms。

    getReceiveOperatorToken() {
        setTimeout(() => {
            this.$axios.post('/api/receiveGoodsQuickly/getReceiveOperatorToken', {
                'sm_admin_id': this.user_value,
                'receive_wh_id': this.receive_wh_id,
                'ad_real_name': this.ad_real_name,
                'mchid': 6001
            }).then((response) => {
                if (response.data['code'] === 0) {
                    this.receive_operator_token = response.data['content'];
                    this.$message({
                        type: 'success',
                        message: '收货人token获取成功'
                    })
                } else {
                    this.$message({
                        type: 'warning',
                        message: response.data['errormsg'],
                    });
                }
            })
        }, 500); // 用setTimeout()
    },
    

    成功解决。

    --不要用肉体的勤奋,去掩盖思考的懒惰--
  • 相关阅读:
    static final常量变量的正确书写规范
    Why aren't more desktop apps written with Qt?(quora.com系列文章)
    建议学个一知半解的时候,再看书
    C++中new和delete的背后(最后还是调用了MSVCR90的malloc)
    关于Qt的事件循环以及QEventLoop的简单使用(QEventLoop::quit()能够终止事件循环,事件循环是可以嵌套的)
    QProcess::startDetached(5.10有了一种新的方式)
    微信公众号支付开发
    Middleware

    TOKEN+签名验证
  • 原文地址:https://www.cnblogs.com/pingguo-softwaretesting/p/14800114.html
Copyright © 2020-2023  润新知