深入浅析Vue.js中 computed和methods不同机制


Posted in Javascript onMarch 22, 2018

在vue.js中,有methods和computed两种方式来动态当作方法来用的

1.首先最明显的不同 就是调用的时候,methods要加上()

2.我们可以使用 methods 来替代 computed,效果上两个都是一样的,但是 computed 是基于它的依赖缓存,只有相关依赖发生改变时才会重新取值。

而使用 methods ,在重新渲染的时候,函数总会重新调用执行

为了方便理解,先上一段源码

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>title</title>
    <script src="https://cdn.bootcss.com/vue/2.4.2/vue.min.js"></script>
  </head>
  <body>
    <div class="test">  <!--computed计算属性-->
      <p>{{now}}</p>
      <p>{{now}}</p>
      <p>{{now}}</p>
      <p>{{now}}</p>
      <hr />      <!--横线分割-->
</div>
    <div class="test2">  <!--methods方法,注意new()加了括号-->
      <p>{{now()}}</p>
      <p>{{now()}}</p>
      <p>{{now()}}</p>
      <p>{{now()}}</p>
    </div>
  </body>
  <script type="text/javascript">
    var myVue = new Vue({
      el: ".test",
      computed: {
        now: function() {
          var yanshi = 0;
          for(var o = 0; o < 2000; o++) {   //延时
            for(var q = 0; q < 2000; q++) {
              yanshi++;
            }
          }
          return Date.now()
        }
      }
    });
    var vue2 = new Vue({
      el: '.test2',
      methods: {
        now: function() {
          var yanshi = 0;
          for(var o = 0; o < 2000; o++) {
            for(var q = 0; q < 2000; q++) {
              yanshi++;
            }
          }
          return Date.now()
        }
      }
    })
  </script>
</html>

运行结果如上,可以看出computed计算属性的话,每次进入页面将一直沿用第一次的信息,不会再触发now,这就是依赖缓存。(有延时的情况下 多次输出时间相同)

那什么是相关依赖发生改变时才会重新取值呢 比方说reversedMessage function()计算属性中调用了message变量

就意味着只要 message 还没有发生改变,多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。

而methods是实时的,在重新渲染时,函数总会重新调用执行,不会缓存,(多次输出时间不同)

可以说使用 computed 性能会更好,但是如果你不希望缓存,你可以使用 methods 属性。

computed 属性默认只有 getter ,不过在需要时你也可以提供一个 setter :所以其实computed也是可以传参的。

ps:下面看下vue计算属性computed和methods的区别

在new Vue的配置参数中的computed和methods都可以处理大量的逻辑代码,但是什么时候用哪个属性,要好好区分一下才能做到正确的运用vue。
computed称为计算属性,顾名思义,计算就要返回一个计算的结果,所以,当我们要处理大量的逻辑,但是最后要取得最后的结果的时候可以用computed;
简单示例:
要求:
<input type="text v-model="num1"><input type="text v-model="num2">
现在要返回num1和num2的和;
<script>
  new Vue({
    el:"#box",
    data:{
        num1:0,
        num2:0
        }
    computed:{  
        result:function(){
            return this.num1 + this.num2  
            // 计算属性必须有一个返回值
        }
    }
   })
</script>
methods:是方法的意思,在js中,我们把一些函数叫做方法,一般情况下,要触发这个方法就要执行,要执行就要有一个源来触发,所以就需要一个事件源。这是和computed的一点不同之处;
methods的示例:
要求:
<\button @click="do()">点击弹出<\/button>
<script>
  new Vue({
    el:"#box",
    data:{
        num1:0,
        num2:0
        }
    methods:{  
        do:function(){
           alert('ok')
           //这里根据情况,可以返回有返回值也可以没有返回值。
        }
    }
   })
</script>
对比computed 和 methods:
computed计算的结果如果不发生改变就不会触发result这个函数。而methods中一般都是定义的需要事件触发的一些函数。每次只要触发事件,就会执行对应的方法。如果把computed中的方法写到method中会浪费性能。
computed必须返回一个值页面绑定的才能取得值,而methods中可以只执行逻辑代码,可以有返回值,也可以没有。

总结

以上所述是小编给大家介绍的Vue.js中 computed和methods不同机制,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
网站上面有这种切换效果
Jun 26 Javascript
checkbox 复选框不能为空
Jul 11 Javascript
jquery 按钮状态效果 正常、移上、按下
Aug 12 Javascript
Js操作Select大全(取值、设置选中等等)
Oct 29 Javascript
jquery实现鼠标滑过显示提示框的方法
Feb 05 Javascript
运行Node.js的IIS扩展iisnode安装配置笔记
Mar 02 Javascript
jQuery实现可以控制图片旋转角度效果(附demo源码下载)
Jan 27 Javascript
jQuery插件zTree实现获取一级节点数据的方法
Mar 08 Javascript
Vue中的字符串模板的使用
May 17 Javascript
Vuex中实现数据状态查询与更改
Nov 08 Javascript
JavaScript中window和document用法详解
Jul 28 Javascript
vue ant design 封装弹窗表单的使用
Jun 01 Vue.js
Java设计中的Builder模式的介绍
Mar 22 #Javascript
使用vue-route 的 beforeEach 实现导航守卫(路由跳转前验证登录)功能
Mar 22 #Javascript
收集前端面试题之url、href、src
Mar 22 #Javascript
vue 的keep-alive缓存功能的实现
Mar 22 #Javascript
bootstrap中selectpicker下拉框使用方法实例
Mar 22 #Javascript
使用Vue开发动态刷新Echarts组件的教程详解
Mar 22 #Javascript
JavaScript分步实现一个出生日期的正则表达式
Mar 22 #Javascript
You might like
不重新编译PHP为php增加openssl模块的方法
2011/06/14 PHP
PHP Switch 语句之学习笔记
2013/09/21 PHP
php文件缓存方法总结
2016/03/16 PHP
PHP使用stream_context_create()模拟POST/GET请求的方法
2016/04/02 PHP
PHP表单数据写入MySQL数据库的代码
2016/05/31 PHP
你真的了解JavaScript吗?
2007/02/24 Javascript
腾讯UED 漂亮的提示信息效果代码
2011/09/12 Javascript
JavaScript执行效率与性能提升方案
2012/12/21 Javascript
IE6下opacity与JQuery的奇妙结合
2013/03/01 Javascript
利用javascript数组长度循环数组内所有元素
2013/12/27 Javascript
jQuery实现鼠标经过提示信息的地图热点效果
2015/04/26 Javascript
js的flv视频播放器插件使用方法
2015/06/23 Javascript
form表单转Json提交的方法(推荐)
2016/09/23 Javascript
Layui实现带查询条件的分页
2019/07/27 Javascript
微信小程序云开发如何实现数据库自动备份实现
2019/08/16 Javascript
VUEX采坑之路之获取不到$store的解决方法
2019/11/08 Javascript
nodejs开发一个最简单的web服务器实例讲解
2020/01/02 NodeJs
nodejs实现百度舆情接口应用示例
2020/02/07 NodeJs
python实现的简单猜数字游戏
2015/04/04 Python
在Python中使用AOP实现Redis缓存示例
2017/07/11 Python
python spyder中读取txt为图片的方法
2018/04/27 Python
使用WingPro 7 设置Python路径的方法
2019/07/24 Python
Django自定义模板过滤器和标签的实现方法
2019/08/21 Python
Python 余弦相似度与皮尔逊相关系数 计算实例
2019/12/23 Python
使用Python爬取弹出窗口信息的实例
2020/03/14 Python
python print 格式化输出,动态指定长度的实现
2020/04/12 Python
Html5写一个简单的俄罗斯方块小游戏
2019/12/03 HTML / CSS
某个公司的Java笔面试题
2016/03/11 面试题
个人简历的自荐信
2013/10/23 职场文书
写给学生的新学期寄语
2014/01/18 职场文书
浪费资源的建议书
2014/03/12 职场文书
个人遵守党的政治纪律情况对照检查材料
2014/09/26 职场文书
工作失职自我检讨书
2015/05/05 职场文书
订货会主持词
2015/07/01 职场文书
Windows 11要来了?微软文档揭示Win11太阳谷 / Win10有两个不同版本
2021/11/21 数码科技
升级 Win11 还是坚守 Win10?微软 Win11 新系统缺失功能大盘点
2022/04/05 数码科技