关于methods、computed、watch的使用
关于methods、computed、watch的使用,前前后后我有转载过好几篇别人的文章。但始终没有自己成型的博文来记录,现自己尝试性的总结一下三者之间的区别:
<template>
<div>
<input type="text" v-model="name" />
<span v-show="isShow">请输入3-6个字符</span>
<br>
<input type="text" v-model="todoName" />
</div>
</template> <script>
export default {
data () {
return {
name: 'zs',
todoName: 'is'
}
},
computed: {
isShow () {
//当this.name的长度小于3或者大于6的时候,显示提示内容(我根据name的变化而变化,别人影响了我)
//一个数据受多个数据影响,这里就是isShow()受到了name长度的影响,也就是别人影响了我
if (this.name.length >= 3 && this.name.length <= 6) {
return false
} else {
return true
}
}
}
}
</script>
再举个自己在实际项目中应用的例子:
这是一个下拉框,下拉框里需要选择不同的设备类型,而且一个项目中有多个页面都用到了这个模块,于是我将它放在了状态管理vuex里面:

这个return this.configList.deviceSubType就是vuex里的返回变量值,通过监控这个值的变化,进而渲染组件中的内容。


总结:
<template>
<div>
<input type="text" v-model="name" />
<span v-show="isShow">请输入3-6个字符</span>
<br>
<input type="text" v-model="todoName" />
</div>
</template> <script>
export default {
data () {
return {
name: 'zs',
todoName: 'is'
}
},
computed: {
isShow () {
//当this.name的长度小于3或者大于6的时候,显示提示内容(我根据name的变化而变化,别人影响了我)
if (this.name.length >= 3 && this.name.length <= 6) {
return false
} else {
return true
}
}
},
watch: {
//监听data中的name,如果发生了变化,就把变化的值给data中的todoName(我影响了别人)
name (newVal) {
this.todoName = newVal
console.log(this.todoName)//输入框中输入name的值,todoname跟着变化
}
},
methods: { }
}
</script>
总结:
1.监听data中的数据的变化
2.监听的数据就是data中的已知值
3.我的变化影响了别人
截图下我在公司项目中用到的实际案例,以下是我在监控echart所用到的watch

这里我监控的是一个对象,用到了watch里的hander。
--------------------------------------------------------------
<template>
<div>
<input type="text" v-model="firstName" />
<!-- <span v-show="isShow">请输入3-6个字符</span> -->
<br />
<input type="text" v-model="lastName" />
</div>
</template> <script>
export default {
data () {
return {
firstName: 'zhang',
lastName: 'fan',
obj1: {
a: 0
}
}
},
computed: {
// 计算结果并返回,只有当被计算的值发生改变时才会触发
// (即:计算属性的结果会被缓存,除非依赖的响应式属性变化才会重新计算)
fullName () {
return this.firstName + '' + this.lastName
}
},
watch: {
// 监听某一个值,当被监听的值发生变化时,执行对应的操作 //监听firstName,当firstName发生变化时就会执行该函数
firstName (newVal) {
//执行需要的操作...
//注:初始化不会执行。只有当被监听的值(firstName)发生变化时才会执行
// this.lastName = newVal
},
//监听lastName,当lastName发生变化时就会执行该函数
lastName: {
handler (newVal, oldVal) {
//执行需要的操作
this.firstName = newVal
},
immediate: true //true: 初始化时就会先执行一遍该监听对应的操作
},
//监听对象obj1,当obj1发生变化时就执行相应的操作
obj1: {
handler () {
//执行需要的操作
},
deep: true//该属性值默认为fasle
// 当被监听的值是对象,只有deep为true时,对应属性的值(obj1.a)发生变化时才能触发监听事件,但是这样非常消耗性能
},
//监听对象具体的属性,deep就不需要设置为true了
'obj1.a': {
handler () {
//执行需要的操作...
}
}
},
持续更新...
关于methods、computed、watch的使用的更多相关文章
- vue中methods,computed,filters,watch的总结
08.28自我总结 vue中methods,computed,filters,watch的总结 一.methods methods属性里面的方法会在数据发生变化的时候你,只要引用了此里面分方法,方法就 ...
- vue methods computed watch区别
一.methods和computed computed是计算属性,methods是方法. html: <p>Reversed message: "{{ reversedMessa ...
- computed,methods,watch
加载顺序: 在官方文档中,强调了computed区别于method最重要的两点 computed是属性调用,而methods是函数调用 computed带有缓存功能,而methods不是 计算属性是基 ...
- watch、computed、methods的区别
1. `computed`属性的结果会被缓存,除非依赖的响应式属性变化才会重新计算.主要当作属性来使用,要return出去一个值:2. `methods`方法表示一个具体的操作,主要书写业务逻辑:3. ...
- computed、methods、watch
computed:计算属性将被混入到 Vue 实例中.所有 getter 和 setter 的 this 上下文自动地绑定为 Vue 实例. methods:methods 将被混入到 Vue 实例中 ...
- Vue 基础自查——watch、computed和methods的区别
1 前言 创建一个Vue实例时,可以传入一个选项对象 const vm = new Vue({ data: { msg: 'hello' }, computed: {}, methods: {}, w ...
- vue中计算属性computed方法内传参
vue中computed计算属性无法直接进行传参 如果有传参数的需求比如说做数据筛选功能可以使用闭包函数(也叫匿名函数)实现 例如: 在上篇博客vue安装使用最后的成绩表练习中的过滤功能的实现: &l ...
- Vue系列之 => computed实现求值
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...
- vue computed计算属性 watch监听
计算属性 computed:{ 变量:function(){ return 计算好的值 } } 这时候计算好的值 就付给了你的变量 在实例中可以this.使用 注意 声明的变量的data中不可以重复声 ...
- computed和watch的用法和区别
computed可以监听v-model(data)中的值,只要值发生变化 他就会重新去计算 computed必须是要有一个返回值的哦 <div id="app"> &l ...
随机推荐
- ELK之elasticsearch安装&&kibana安装
1.ES和Kibana安装都是开箱即用的? 解压缩就可以用 elasticsearch解压缩之后,双击下图中的elasticsearch.bat,启动,kibana也是一样 双击之后, 我们看到上图有 ...
- ubuntu更新问题
ubuntu 下出现E: Sub-process /usr/bin/dpkg returned an error code 在用apt-get安装软件时出现了类似于install-info: No d ...
- 2019-4-29-dotnet-core-通过-frp-发布自己的网站
title author date CreateTime categories dotnet core 通过 frp 发布自己的网站 lindexi 2019-04-29 12:26:45 +0800 ...
- python 类的创建
- Spring Data JPA 查询结果返回至自定义实体
本人在实际工作中使用Spring Data Jpa框架时,一般查询结果只返回对应的Entity实体.但有时根据实际业务,需要进行一些较复杂的查询,比较棘手.虽然在框架上我们可以使用@Query注解执行 ...
- 【vb.net机房收费系统】之没有包含要从继承的组件的已生成程序集 标签: vb.net继承 2015-05-02 15:19 1012人阅读
在敲到组合查询这个功能的时候,需要用到窗体的继承,但是在新建继承窗体的时候,出现了错误(没有包含要从继承的组件的已生成程序集).如下图: 问题的产生:当时没怎么注意,也不知道怎么弄的,最后反正是继承上 ...
- 9-1进程,进程池和socketserver
一 进程: # 什么是进程 : 运行中的程序,计算机中最小的资源分配单位# 程序开始执行就会产生一个主进程# python中主进程里面启动一个进程 —— 子进程# 同时主进程也被称为父进程# 父子进程 ...
- 洛谷P2330 [SCOI2005]繁忙的都市
#include<bits/stdc++.h> using namespace std; ; ; int n,k,Max,tot; struct node{ int cnt,fa; }f[ ...
- @topcoder - SRM611D1L3@ ElephantDrinking
目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定有一个 n*n 的平原,其中一些格子有些泉水.泉水每单位时间 ...
- HZOJ 大佬(kat)
及其水水水的假期望(然而我已经被期望吓怕了……). 数据范围及其沙雕导致丢掉5分…… 因为其实每天的期望是一样的,考虑分开. f[i][j]表示做k道题,难度最大为j的概率. 则f[i][j]=(f[ ...