zoukankan      html  css  js  c++  java
  • vue计算属性和监听器

    1. 模板里使用表达式

      • 模板语法里使用表达式进行一些操作

        <div id="app">
            {{ message.split('').reverse().join('')}}
        </div>
        <script>
            const app = new Vue({
                el:'#app',
                data() {
                    return {
                        message:'hello,vue'
                    }
                }
            })
        </script>
        
      • 如果表达式足够复杂,会很难处理,并且不够优美且很难理解

    2. 使用方法

      • 调用方法代替表达式

        <div id="app">
            {{reversedMessage()}}
        </div>
        <script>
            const app = new Vue({
                el:'#app',
                data() {
                    return {
                        message:'hello,vue'
                    }
                },
                methods: {
                   reversedMessage(){
                        return this.message.split('').reverse().join('')
                   }
                }, 
        
            })
        </script>
        
      • 每次渲染模板的时候都需要调用一次方法,并且不能触发缓存,比较浪费性能。所以引入基于响应式依赖进行缓存的计算属性

    3. 使用计算属性

      • 只在相关响应式依赖发生改变时它们才会重新求值

        <div id="app">
            {{reversedMessage}}
        </div>
        <script>
            const app = new Vue({
                el:'#app',
                data() {
                    return {
                        message:'hello,vue'
                    }
                },
                computed: {
                    reversedMessage() {
                        return this.message.split('').reverse().join('')
                    }
                },
            })
        </script>
        
      • 计算属性默认只有 getter,不过在需要时你也可以提供一个 setter

        computed: {
          fullName: {
            // getter
            get: function () {
              return this.firstName + ' ' + this.lastName
            },
            // setter
            set: function (newValue,oldValue) {
              var names = newValue.split(' ')
              this.firstName = names[0]
              this.lastName = names[names.length - 1]
            }
          }
        }
        
    4. 使用监听器

      • 普通方法:虽然计算属性在大多数情况下更合适,但有时也需要一个自定义的侦听器,一种更通用的方式来观察和响应 Vue 实例上的数据变动

        <div id="app">
            <input type="text"  v-model='message'>
            <p>{{reversedMessage}}</p>
        </div>
        <script>
            const app = new Vue({
                el:'#app',
                data() {
                    return {
                        message:'hello,vue',
                        reversedMessage:'',
                    }
                },
                watch: {
                    message(newValue,oldValue){//这种这种不能立马生效,因为初始化时不会触发
                        this.reversedMessage = newValue.split('').reverse().join('')
                    }
                },
            })
        </script>
        
      • 立即执行:immediate立即执行一次

        <div id="app">
            <input type="text"  v-model='message'>
            <p>{{reversedMessage}}</p>
        </div>
        <script>
            const app = new Vue({
                el:'#app',
                data() {
                    return {
                        message:'hello,vue',
                        reversedMessage:'',
                    }
                },
                watch: {
                    message: {
                        immediate: true,
                        handler: function (newValue, oldVal) {
                            this.reversedMessage = newValue.split('').reverse().join('')
                        }
                    },
                },
            })
        </script>
        
      • 监听复杂对象:为了发现对象内部值的变化,可以在选项参数中指定 deep: true。注意监听数组的变更不需要这么做

         <div id="app">
            <input type="text" v-model='message.deepMsg'>
            <p>{{reversedMessage}}</p>
        </div>
        <script>
            const app = new Vue({
                el:'#app',
                data() {
                    return {
                        message:{deepMsg:'hello,vue'},
                        reversedMessage:'',
                    }
                },
                watch: {
                    message: {
                        //immediate: true,
                        deep:true,
                        handler: function (newValue, oldVal) {
                            this.reversedMessage = newValue.deepMsg.split('').reverse().join('')
                        }
                    },
                },
            })
        </script>
        
    5. 计算属性和监听器的比较

      • 处理数据的场景不同,监听器适合一个数据影响多个数据,计算属性适合一个数据受多个数据影响

      • 计算属性有缓存性,计算所得的值如果没有变化不会重复执行

      • 监听器选项提供了更通用的方法,适合执行异步操作或较大开销操作的情况

        <div id="app">
            <input type="text" v-model='message'>
            <p>{{addMessage}}</p>
        </div>
        <script>
            const app = new Vue({
                el:'#app',
                data() {
                    return {
                        message:'hello,vue',
                        addMessage:'',
                    }
                },
                watch: {
                    message(val){
                        this.addMessage ='wait.....';
                        setTimeout(()=>{
                            this.addMessage = 'change'
                        },2000)
                    },
                },
            })
        </script>
        
  • 相关阅读:
    python virtualenv
    ICMP
    正则表达式
    tcpdump命令
    vim命令
    IP网际协议
    链路层
    python模块学习 logging
    Angular2+如何去除url中的#
    angular5懒加载之模块划分
  • 原文地址:https://www.cnblogs.com/EricZLin/p/14003164.html
Copyright © 2011-2022 走看看