深入浅析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 相关文章推荐
Javascript中的Split使用方法与技巧
Mar 09 Javascript
非常漂亮的JS代码经典广告
Oct 21 Javascript
JavaScript的变量作用域深入理解
Oct 25 Javascript
分享几个超级震憾的图片特效
Jan 08 Javascript
Javascript遍历Html Table示例(包括内容和属性值)
Jul 08 Javascript
JavaScript简介
Feb 15 Javascript
JS使用post提交的两种方式
Dec 03 Javascript
javascript制作照片墙及制作过程中出现的问题
Apr 04 Javascript
vue.js学习笔记之绑定style样式和class列表
Oct 31 Javascript
基于jQuery的checkbox全选问题分析
Nov 18 Javascript
jQuery插件jqGrid动态获取列和列字段的方法
Mar 03 Javascript
详解vue-cli项目中用json-sever搭建mock服务器
Nov 02 Javascript
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
异世界新番又来了,同样是从零开始,男主的年龄降到5岁
2020/04/09 日漫
详解强大的jQuery选择器之基本选择器、层次选择器
2012/02/07 Javascript
jquery动画1.加载指示器
2012/08/24 Javascript
JS判断不同分辨率调用不同的CSS样式文件实现思路及测试代码
2013/01/23 Javascript
jQuery 隐藏和显示 input 默认值示例
2014/06/03 Javascript
JavaScript实现广告的关闭与显示效果实例
2015/07/02 Javascript
javascript运动详解
2015/07/06 Javascript
jQuery实现的数值范围range2dslider选取插件特效多款代码分享
2015/08/27 Javascript
JS动态改变浏览器标题的方法
2016/04/06 Javascript
JS插件plupload.js实现多图上传并显示进度条
2016/11/29 Javascript
Centos6.8下Node.js安装教程
2017/05/12 Javascript
React-Native中props具体使用详解
2017/09/04 Javascript
Node.JS使用Sequelize操作MySQL的示例代码
2017/10/09 Javascript
javascript实现数字配对游戏的实例讲解
2017/12/14 Javascript
webpack 开发和生产并行设置的方法
2018/11/08 Javascript
详解js静态检查工具eslint配置文件
2018/11/23 Javascript
JavaScript跳出循环的三种方法(break, return, continue)
2019/07/30 Javascript
详解微信小程序工程化探索之webpack实战
2020/04/20 Javascript
在Django的视图(View)外使用Session的方法
2015/07/23 Python
python使用正则表达式的search()函数实现指定位置搜索功能
2017/11/10 Python
在Python中使用turtle绘制多个同心圆示例
2019/11/23 Python
python 浅谈serial与stm32通信的编码问题
2019/12/18 Python
keras自定义损失函数并且模型加载的写法介绍
2020/06/15 Python
pyspark对Mysql数据库进行读写的实现
2020/12/30 Python
50个强大璀璨的CSS3/JS技术运用实例
2010/02/27 HTML / CSS
TUMI香港官网:国际领先的行李箱、背囊品牌
2021/03/01 全球购物
报关报检委托书
2014/04/08 职场文书
白岩松演讲
2014/05/21 职场文书
公共场所标语
2014/06/30 职场文书
学生上课迟到检讨书
2015/01/01 职场文书
成绩单评语
2015/01/04 职场文书
党员转正意见怎么写
2015/06/03 职场文书
小人国观后感
2015/06/11 职场文书
Rust 连接 PostgreSQL 数据库的详细过程
2022/01/22 PostgreSQL
【海涛DOTA】D-cup邀请赛NV.cn vs DT.Love
2022/04/01 DOTA
《王国之心》迎来了发售的20周年, 野村哲发布贺图
2022/04/11 其他游戏