• Vue中计算属性computed与method的区别


    目录

    ❣️ 什么是计算属性?

    ❣️ computed实例

    ❣️ computed与method的区别

    ❣️ 关于传参问题

    ❣️ 总结


    目前工作中,很多公司都把vue作为自己的前端框架,vue的开发者和研究者也越来越多;不知道有多少人在研究使用vue的时候,对computed和methods到底有什么区别都不是特别明白。因为我们发现,想要实现一个需求,我们使用两种方式中的任何一个,基本上都可以实现,那么我们平时应该用什么更好呢?

    ❣️ 什么是计算属性?

    提到计算属性,就不得不先提一下Vue中的另一个内容,它就是插值表达式。话不多说,先上一个案例,来见识一下何为插值表达式:

    1. <!DOCTYPE html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8">
    5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
    6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
    7. <title>Document</title>
    8. <script src="js/vue.js"></script>
    9. </head>
    10. <body>
    11. <div id="app">
    12. <p>{{msg}}</p>
    13. </div>
    14. <script>
    15. var vm=new Vue({
    16. el:"#app",
    17. data:{
    18. msg:"vue的绑定语法,学名叫插值语法",
    19. }
    20. })
    21. </script>
    22. </body>
    23. </html>

     运行结果:

    上面这个案例就是一个Vue插值表达式的实例,通过这个例子,我们不难看出,插值表达式的语法相当简洁,使用起来也很方便。但是也不免暴露出它的一些缺点,最典型的就是无法进行复杂逻辑运算。所以,Vue才会自带计算属性的功能。

    话说到这里,大家应该也就了解了,计算属性的本质就是辅助插值表达式来进行复杂逻辑运算的

    ❣️ computed实例

    下面,我们通过一段代码来具体看一下Vue中计算属性的实际应用:

    1. <!DOCTYPE html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    7. <title>Document</title>
    8. <script src="js/vue.js"></script>
    9. </head>
    10. <body>
    11. <div id="app">
    12. <div>{{msg}}</div>
    13. <div>{{reverseString}}</div>
    14. </div>
    15. <script>
    16. var vm = new Vue({
    17. el: "#app",
    18. data: {
    19. msg: "大家好,我是儒雅的烤地瓜,请多多指教",
    20. },
    21. methods: {},
    22. computed: {
    23. // 也可以使用对象方法的简写:reverseString(){...}
    24. reverseString: function () {
    25. return this.msg.split("").reverse().join("");
    26. },
    27. },
    28. });
    29. </script>
    30. </body>
    31. </html>

    运行结果:

    上面这个案例就是一个computed的实例演示,我们通过代码不难看出:第一个p标记中的插值表达式显示的是原文,而第二个p标记中,显示的则是经过一系列API处理之后的文本内容。

    其中,所有的API操作都放在了computed中的reverseString方法中来实现,而最终插值表达式,只是将computed中处理完毕的属性绑定给自己即可。这也从另一个侧面证实了computed只负责进行复杂逻辑运算的特点

    ❣️ computed与method的区别

    在Vue中,有computed和methods两个模块,且这两个模块都可以进行方法的编写。那么问题来了,二者之间到底有何区别?

    首先,计算属性是基于它们的依赖进行缓存的,只有在依赖发生改变的时候,它们才会重新计算,否则,它们是不变的。换句话说,就是每次访问计算属性时,如果依赖没有发生改变,它们可以立即返回结果,而不需要进行复杂的逻辑运算。而methods中的方法,只要被触发,被调用的方法就会立即执行对应函数,重新进行渲染。

    其次,计算属性是具有缓存性质的,而methods中的方法,则不具备缓存的能力,下面通过一个代码片段来进行演示:

    1. <!DOCTYPE html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    7. <title>Document</title>
    8. <script src="js/vue.js"></script>
    9. </head>
    10. <body>
    11. <div id="app">
    12. <!-- 原始属性输出的结果 -->
    13. <p>{{msg}}</p>
    14. <!-- methodDome方法输出的结果 -->
    15. <p>{{methodDome()}}</p>
    16. <!-- 计算属性输出的结果 -->
    17. <p>{{computedDome}}</p>
    18. </div>
    19. <script>
    20. var vm = new Vue({
    21. el: "#app",
    22. data: {
    23. msg: "Hello Vue"
    24. },
    25. methods: {
    26. // 也可以使用对象方法的简写:methodDome(){...}
    27. methodDome:function(){
    28. return this.msg.split(' ').reverse().join("===");
    29. }
    30. },
    31. computed: {
    32. // 也可以使用对象方法的简写:computedDome(){...}
    33. computedDome:function(){
    34. return this.msg.split(' ').reverse().join("===");
    35. }
    36. },
    37. });
    38. </script>
    39. </body>
    40. </html>

    运行结果:

    通过上面这个案例,我们可以看出,computed和methods在输出的结果上是一致的,只不过在计算结果这个过程中,有所不同。一个是利用依赖关系进行缓存,只要依赖不变,值就不变;一个是被调用,重新执行函数。 

    再举一个类似例子,如下:

    1. <!DOCTYPE html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <title>Document</title>
    6. </head>
    7. <body>
    8. <div id="app">
    9. <div>{{reverseString}}</div>
    10. <div>{{reverseMessage()}}</div>
    11. </div>
    12. <script src="js/vue.js"></script>
    13. <script>
    14. /* 计算属性与方法的区别:计算属性是基于依赖进行缓存的,而方法不缓存 */
    15. var vm = new Vue({
    16. el: "#app",
    17. data: {
    18. msg: "Nihao",
    19. num: 100,
    20. },
    21. computed: {
    22. reverseString: function () {
    23. console.log("computed");
    24. // return this.msg.split('').reverse().join('');
    25. var total = 0;
    26. for (var i = 0; i <= this.num; i++) {
    27. total += i;
    28. }
    29. return total;
    30. },
    31. },
    32. methods: {
    33. reverseMessage: function () {
    34. console.log("methods");
    35. return this.msg.split("").reverse().join("");
    36. },
    37. },
    38. });
    39. </script>
    40. </body>
    41. </html>

    运行结果: 

    ❣️ 关于传参问题

    用过methods的同学一定知道,methods中定义的所有方法都是可以进行参数传递的,但是computed中的方法可以进行参数传递吗?

    其实,我们如果仔细看一下Vue的官方文档,就会发现,官方文档说明中,并不支持的在computed中进行传参操作。那么问题来了,假如现在就想在computed中进行传参操作该怎么做呢?

    其实也很简单,在JavaScript语言中,我们提到过闭包这种设计,它的主要作用,不就是用来访问其他函数内部的变量,然后返回操作结果。所以,我们可以利用闭包来实现。

    1. :data="closure(item,itemName,blablaParams)"
    2. computed: {
    3. closure(){
    4. return function(a,b,c){
    5. // do something
    6. return data
    7. }
    8. }
    9. }

    ❣️ 总结

    通过上面概述我们不难发现,Vue的computed主要是用来进行组件复杂逻辑运算的,辅助插值表达式来简化结构性代码,让开发人员更专注与数据层的操作。

    同时,对于一些运算复杂,且依赖变化较小的功能块,也可以从methods中移到computed中,来提高代码的运行速度,在方法传参方面,可以利用JavaScript的闭包设计来完成传参。

  • 相关阅读:
    MySQL索引
    python实现灰色关联法(GRA)
    【SpringMVC】JSON注解&异常处理的使用
    Unicode和UTF-8的关系
    Python开发技术—函数设计1
    java的入门学习
    使用 Java 解析 Apache 日志文件
    YashanDB个人版正式开放下载!参与首批体验官活动赢好礼!
    leetcode 94.二叉树的中序遍历(非递归和递归遍历)
    PaddleOCR简单使用教程-Windows
  • 原文地址:https://blog.csdn.net/sunyctf/article/details/125084723