zoukankan      html  css  js  c++  java
  • vue 监听变量或对象

    注意:监听的对象必须已经在data中声明了

     data: {
        a: 1,
        b: 2,
        c: 3,
        d: 4,
        e: {
          f: {
            g: 5
          }
        }
      },
      watch: {
        a: function (val, oldVal) {
          console.log('new: %s, old: %s', val, oldVal)
        },
        // string method name
        b: 'someMethod',
        // deep watcher 
        e: {
          handler: function (val, oldVal) { /* ... */ },
          deep: true
        },
        // the callback will be called immediately after the start of the observation
        d: {
          handler: function (val, oldVal) { /* ... */ },
          immediate: true
        },
        e: [
          function handle1 (val, oldVal) { /* ... */ },
          function handle2 (val, oldVal) { /* ... */ }
        ],
        // watch vm.e.f's value: {g: 5}
        'e.f': function (val, oldVal) { /* ... */ }
      }
    })
    vm.a = 2 // => new: 2, old: 1
    

      比如下面例子

    //监听某个变量
    watch: {
        bet(newValue, oldValue) {
            console.log(newValue);
        }
    }
    //监听对象 某一个属性
    watch: {
      'bet.text': function (val, oldVal) {}
    }
    //监听 整个对象(数组)
    serviceList:{
                handler(){   //注意此处就是handler
                    console.log(this.serviceList);
                },
                deep:true, 
                immediate: true // watch 的一个特点是,最初绑定的时候是不会执行的,要等到 serviceList 改变时才执行监听计算。加上改字段让他最初绑定的时候就执行
            },
    

      

    对于vue的深层对象数组的监控 可能不能得到及时的刷新 直接对比oldVal 和newVal时可能对比不出变化来,若想根据具体值的变化 而对内部其他的参数赋值 需要在nextTick里面进行,比如:

    deep1.pars  pars 是 [{min:'',max:'',fix:''},{min:'',max:'',fix:''}]
    需求时pars数组的第一项的max的变化修改第二项的min值等于第一项的max 通过监控deep1.pars的变化 对内部元素赋值时需要使用nextTick
    但是建议若是min和max是用户触发的 可以使用change事件去监控变化并且做相应的修改操作
     
  • 相关阅读:
    Vue打包之后部署到 express 服务器上
    Vue 点击事件传递原生DOM事件?
    CSS hover 改变另外一个元素状态
    element-UI el-table二次封装
    element-UI el-table添加序号列时序号永远都是从1开始?
    element-UI el-table表格根据搜索条件表格值改变颜色
    HTML head meta标签详细
    CodeForces 489C Given Length and Sum of Digits... (dfs)
    CodeForces 489B BerSU Ball (水题 双指针)
    Codeforces 489A SwapSort (水题)
  • 原文地址:https://www.cnblogs.com/xhliang/p/9260596.html
Copyright © 2011-2022 走看看