VUE:计算属性和监视

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>
    <body>
        <!--
            1、计算属性:
                在computed属性对象中定义计算属性的方法
                在页面中使用{{方法名}}来显示计算结果
            2、监视属性:
                通过vm对象的$watch()或watch配置来监视指定的属性
                当属性变化时,回调函数自动调用,在函数内部进行计算
            3、计算属性高级:
                通过getter/setter实现对属性数据的显示和监视
                计算属性存在缓存,多次读取只执行一次getter计算
        -->

        <div id="app">
            姓:<input type="text" placeholder="First Name" v-model="firstName"/><br />
            名:<input type="text" placeholder="Last Name" v-model="lastName" /><br />
            姓名1(单向):<input type="text" placeholder="Full Name1" v-model="fullName1"/><br />
            姓名2(单向):<input type="text" placeholder="Full Name2" v-model="fullName2"/><br />
            姓名3(双向):<input type="text" placeholder="Full Name3" v-model="fullName3"/><br />
        </div>

        <script type="text/javascript" src="../js/vue.js" ></script>
        <script type="text/javascript">
            //const常量
            const vm=new Vue({
                el:"#app",
                data:{
                    firstName:‘A‘,
                    lastName:‘B‘,
                    fullName2:‘A B‘
                },
                computed:{
                    //计算属性的方法,方法的返回值作为属性值。
                    //执行条件:初始化显示的时候或data发生改变的时候调用
                    fullName1(){
                        return this.firstName+‘ ‘+this.lastName;
                    },
                    fullName3:{
                        //回调函数(1.你定义的,2.你没有调,3.但最终它执行了)计算并返回结果
                        //当需要读取当前属性值时回调,根据相关的数据计算并返回当前属性的值
                        get(){
                            return this.firstName+‘ ‘+this.lastName;
                        },
                        //当属性值发生改变时回调,更新相关的属性数据
                        //value:fullName3的最新值
                        set(value){
                            const names=value.split(‘ ‘);
                            this.firstName=names[0];
                            this.lastName=names[1];
                        }
                    }

                },
                watch:{
                    //传参    (新的值,旧的值) 或 (旧的值)
                    firstName:function(value){
                        this.fullName2=value+‘ ‘+this.lastName;
                    },
                    /*lastName:function(value){
                        this.fullName2=this.firstName+‘ ‘+value;
                    }*/
                }
            })

            vm.$watch(‘lastName‘,function(value){
                    this.fullName2=this.firstName+‘ ‘+value;
            })
        </script>
    </body>
</html>

重点:计算属性存在缓存

原文地址:https://www.cnblogs.com/it-taosir/p/9886664.html

时间: 2024-11-06 07:13:27

VUE:计算属性和监视的相关文章

在做vue计算属性,v-for处理数组时遇到的一个bug

问题 bug: You may have an infinite update loop in a component render function 无限循环 需要处理的数组(在 ** ssq **里): bonus_code: ['01', '19', '25', '26', '27', '33', '10'] 计算属性 computed: ssqRed: function() { return this.ssq.bonus_code.splice(0, 6) }, ssqBlue: fun

Vue#计算属性

在模板中表达式非常便利,但是它们实际上只用于简单的操作.模板是为了描述视图的结构.在模板中放入太多的逻辑会让模板过重且难以维护.这就是为什么 Vue.js 将绑定表达式限制为一个表达式.如果需要多于一个表达式的逻辑,应当使用计算属性. 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>Documen

vue计算属性和观察者

1. 计算属性 模板内的表达式非常便利,但在模板中放入太多的逻辑会让模板过重且难以维护,所有就有了计算属性 例子: //html代码 <div id="example"> <p>Original message: "{{ message }}"</p> <p>Computed reversed message: "{{ reversedMessage }}"</p> </div&g

Vue计算属性和监听属性

一.计算属性 计算属性关键词: computed.计算属性在处理一些复杂逻辑时是很有用的. 可以看下以下反转字符串的例子: <div id="app"> {{ message.split('').reverse().join('') }} </div> //模板变的很复杂起来,也不容易看懂理解 使用了计算属性的实例: <div id="app"> <p>原始字符串: {{ message }}</p> &l

vue计算属性详解——小白速会

每天学习一点点 编程PDF电子书.视频教程免费下载: http://www.shitanlife.com/code 一.什么是计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护.例如: <div id="example"> {{ message.split('').reverse().join('') }} </div> 这里的表达式包含3个操作,并不是很清晰,所以遇到复杂逻辑时应该使用Vue特带的

Vue计算属性

计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护.例如: <div id="example"> {{ message.split('').reverse().join('') }} </div> 在这个地方,模板不再是简单的声明式逻辑.你必须看一段时间才能意识到,这里是想要显示变量 message 的翻转字符串.当你想要在模板中多次引用此处的翻转字符串时,就会更加难以处理. 所以,对于任何复杂逻辑

VUE 计算属性 vs 侦听属性

计算属性 vs 侦听属性 Vue 提供了一种更通用的方式来观察和响应 Vue 实例上的数据变动:侦听属性.当你有一些数据需要随着其它数据变动而变动时,你很容易滥用 watch——特别是如果你之前使用过 AngularJS.然而,通常更好的做法是使用计算属性而不是命令式的 watch 回调.细想一下这个例子: <div id="demo">{{ fullName }}</div> var vm = new Vue({ el: '#demo', data: { fi

Vue计算属性和侦听器

计算属性 模板内的表达式非常便利,但是在模板中放入太多的逻辑会让模板过重切难以维护.对于任何复杂逻辑都应该使用计算属性. <p>{{ reverseMsg }}</> var vm = new Vue({ el: '#example', data: { message: 'hello' }, computed: { reverseMsg: function() { return this.message } } }) 这里声明一个计算属性reverseMsg.我们提供的函数将作用属

vue - 计算属性、监听、自定义指令

1.计算属性 <div id="app"> <input type="text" v-model="x"> <input type="text" v-model="y"> {{get}} </div> <script> var app=new Vue({ el:"#app", data:{ x:"", y:&