浅析Vue中method与computed的区别
在new vue的配置参数中的computed和methods都可以处理大量的逻辑代码,但是什么时候用哪个属性,要好好区分一下才能做到正确的运用vue。
computed称为计算属性,顾名思义,计算就要返回一个计算的结果,所以,当我们要处理大量的逻辑,但是最后要取得最后的结果的时候可以用computed;
为了说明method与computed的区别,在此我想先来看看computed属性在vue官网中的说法:模板内的表达式是非常便利的,但是它们实际上只用于简单的运算。在模板中放入太多的逻辑会让模板过重且难以维护。
我们来看一个例子:
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>title</title> <script src="javascript/vue.min.js"></script> </head> <body> <div id="app"> //直接在模板中绑定表达式 <p>{{message.split('').reverse().join('')}}</p> //运用计算属性 <p>message反转之后的结果:{{reversemessage}}</p> </div> <script> var vm=new vue({ el:"#app", data:{ message:"hello" }, computed:{ reversemessage:function(){ return this.message.split('').reverse().join(''); } } }) </script> </body> </html>
在上面这种情况下,模板不再简单和清晰。在意识到这是反向显示 message 之前,你不得不再次确认第二遍。当你想要在模板中多次反向显示 message 的时候,问题会变得更糟糕。这就是对于任何复杂逻辑,你都应当使用计算属性的原因。下面我将运用method与computed进行比较:
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>title</title> <script src="javascript/vue.min.js"></script> </head> <body> <div id="app"> <p>{{message}}</p> //直接在模板中绑定表达式 <p>{{message.split('').reverse().join('')}}</p> //运用计算属性 <p>{{reversemessage}}</p> //运用methods方式 <p>{{methodmessage()}}</p> </div> <script> var vm=new vue({ el:"#app", data:{ message:"hello" }, computed:{ reversemessage:function(){ return this.message.split('').reverse().join(''); } }, methods:{ methodmessage:function () { return this.message.split('').reverse().join(''); } } }) </script> </body> </html>
我在将这二种方式进行了比较。返回的结果是一样的,写但在法上computed计算属性的方式在用属性时不用加(),而methods方式在使用时要像方法一样去用,必须加().
两种方式在缓存上也大有不同,利用computed计算属性是将 reversemessage与message绑定,只有当message发生变化时才会触发reversemessage,而methods方式是每次进入页面都要执行该方法,但是在利用实时信息时,比如显示当前进入页面的时间,必须用methods方式。
总结
以上所述是小编给大家介绍的vue中method与computed的区别,希望对大家有所帮助
下一篇: CDR怎么设计一款双层立体文字效果?
推荐阅读
-
浅析Java中Map与HashMap,Hashtable,HashSet的区别
-
浅析java中ArrayList与Vector的区别以及HashMap与Hashtable的区别
-
浅析C#中数组,ArrayList与List对象的区别
-
浅析Java中Map与HashMap,Hashtable,HashSet的区别
-
浅析java中ArrayList与Vector的区别以及HashMap与Hashtable的区别
-
浅析Java中String与StringBuffer拼接的区别
-
浅析Java中String与StringBuffer拼接的区别
-
Vue中的methods、watch、computed的区别
-
Vue中computed和watch的区别
-
深入浅析php中sprintf与printf函数的用法及区别