Vue中watch与computed的区别
一、 计算属性(computed)
1.计算属性是为了模板中的表达式简洁,易维护,符合用于简单运算的设计初衷。对于运算过于复杂,冗长,且不好维护,因此我们对于复杂的运算应该 使用计算属性的方式去书写。
下面来看代码体验一下吧
<div id="app">
<h1>
{{ myname.substring(0,1).toUpperCase() + myname.substring(1) }}
</h1>
</div>
<script>
const app = new Vue({
el: '#app',
data: {
myname: 'xiaowu3'
}, })
</script>
由上可以看出在html标签中的代码过多,不方便于我们进行对代码的管理,因此我们可以利用计算属性computed对其进行简化
<div id="app">
<h1>
{{ changewords}}
</h1>
</div>
<script>
const app = new Vue({
el: '#app',
data: {
myname: 'xiaowu3'
},
computed: {
changewords() {
return this.myname.substring(0, 1).toUpperCase() + this.myname.substring(1)
}
} })
</script>
总结:
1.变量不在 data中定义,而是定义在computed中,写法跟写方法一样,有返回值。函数名直接在页面模板中渲染,不加小括号 。
2.根据传入的变量的变化 进行结果的更新。
3.计算属性基于响应式依赖进行缓存。如其中的任意一个值未发生变化,它调用的就是上一次 计算缓存的数据,因此提高了程序的性能。而methods中每调用一次就会重新计算 一次,为了进行不必要的资源消耗,选择用计算属性。
二、监听属性(watch)
上面说到计算属性的时候 初始化的时候就可以被监听到并且计算 但是watch是发生改变的时候才会触发。
当你有一些数据需要随着其它数据变动而变动时,或者当需要在数据变化时执行异步或开销较大的操作时,你可以使用 watch。
看下面代码体验一下吧
body>
<div id="app">
<p>单价:<input type="text" v-model="price"></p>
<p>数量:<input type="text" v-model="number"></p>
<p>计算金额:{{sum}}</p>
</div>
</body>
<script>
const app = new Vue({
el: "#app",
data: {
price: 100,
number: 1,
sum: 100
},
//监听某一个值或者状态发生变化 变化就会触发watch
watch: {
// 监听的参数的名字要一致
price() {
console.log(this.price)
if (this.price * this.number < 1000 && this.price * this.number > 0) {
this.sum = this.price * this.number + 100
} else {
this.sum = this.price * this.number
}
},
number() {
console.log(this.price)
if (this.price * this.number < 1000 && this.price * this.number > 0) {
this.sum = this.price * this.number
} else {
this.sum = this.price * this.number
}
}
}
})
</script>
三.它们的使用场景
Vue中watch与computed的区别的更多相关文章
- Vue中method与computed的区别
		
为了说明method与computed的区别,在此我想先来看看computed属性在vue官网中的说法:模板内的表达式是非常便利的,但是它们实际上只用于简单的运算.在模板中放入太多的逻辑会让模板过重且 ...
 - vue中methods、computed、watch区别
		
vue中methods.computed.watch区别methods:事件调用的钩子 computed:{ // 计算属性是根据他依赖的值计算的,当依赖值发生变化,其跟着改变 // 计算属性是依赖缓 ...
 - vue中assets和static的区别
		
Vue中assets和static的区别 再一次框架定型中,与同事在静态资源的存放上有了一些分歧,后来经过查阅总结如下: 相同点: assets和static两个都是存放静态资源文件.项目中所需要 ...
 - 浅谈Vue中计算属性computed的实现原理
		
虽然目前的技术栈已由Vue转到了React,但从之前使用Vue开发的多个项目实际经历来看还是非常愉悦的,Vue文档清晰规范,api设计简洁高效,对前端开发人员友好,上手快,甚至个人认为在很多场景使用V ...
 - vue 中 assets 和 static 的区别
		
Vue中的静态资源管理(src下的assets和static文件夹的区别)
 - vue中计算属性computed方法内传参
		
vue中computed计算属性无法直接进行传参 如果有传参数的需求比如说做数据筛选功能可以使用闭包函数(也叫匿名函数)实现 例如: 在上篇博客vue安装使用最后的成绩表练习中的过滤功能的实现: &l ...
 - vue中$route 和$router的区别
		
在vue中会出现一种情况 const url=this.$route.query.returnURL; this.$router.push(url); $router和$route的区别傻傻的分 ...
 - 简述vue中v-if和v-show的区别
		
vue中的 v-if 和 v-show 二者都可以动态的控制元素的隐藏和显示,但是他们控制的原理是不同的 v-if v-if 控制元素显示或隐藏是把dom元素整个的渲染或者删除,如果删除,也就是页面中 ...
 - Vue中使用watch computed
		
watch:监听属性,来监听dta中的数据变化 或者route的变化 computed:计算属性, <!DOCTYPE html> <html lang="en" ...
 
随机推荐
- 第4讲 | DHCP与PXE:IP是怎么来的,又是怎么没的?
			
第4讲 | DHCP与PXE:IP是怎么来的,又是怎么没的? linux 配置网络IP地址: 使用 net-tools: sudo ifconfig eth1 10.0.0.1/24 sudo ifc ...
 - App自动化测试之Appium环境安装(涉及雷电模拟器和真机)
			
1.安装Microsoft .NET Framework 4.5 及以上版本 2.安装Appium 官方网站地址:http://appium.io/ 我装了1.17.0版本 3.安装JDK 1.8及以 ...
 - Go string 详解
			
前言 字符串(string) 作为 go 语言的基本数据类型,在开发中必不可少,我们务必深入学习一下,做到一清二楚. 本文假设读者已经知道切片(slice)的使用,如不了解,可阅读 Go 切片 基本知 ...
 - ONNX MLIR方法
			
ONNX MLIR方法 MLIR中的开放式神经网络交换实现. Prerequisites gcc >= 6.4 libprotoc >= 3.11.0 cmake >= 3.15.4 ...
 - 从单一图像中提取文档图像:ICCV2019论文解读
			
从单一图像中提取文档图像:ICCV2019论文解读 DewarpNet: Single-Image Document Unwarping With Stacked 3D and 2D Regressi ...
 - Spring boot未授权访问造成的数据库外联
			
一.spring boot 日常测试或攻防演练中像shiro,fastjson等漏洞已经越来越少了,但是随着spring boot框架的广泛使用,spring boot带来的安全问题也越来越多,本文仅 ...
 - 彻底删除Docker
			
yum remove docker \ docker-client \ docker-client-latest \ docker-common \ docker-latest \ docker-la ...
 - 【NX二次开发】体素特征相关函数(块、柱、锥、球)
			
NX Open允许用户创建和查询所有基本体素特征,通过API函数建立基本体素特征返回的是相应的特征标识,如果需要可以通过函数UG_MODL_ask_feat_body()获得特征对应的实体对象标识.基 ...
 - 【NX二次开发】多功能对话框UF_UI_message_dialog
			
多功能对话框 1 extern DllExport void ufsta(char *param, int *returnCode, int rlen) 2 { 3 UF_initialize(); ...
 - 【SQLite】教程02-SQLite命令
			
获取帮助 sqlite> .help 获得以下帮助: 命令 描述 .backup ?DB? FILE 备份 DB 数据库(默认是 "main")到 FILE 文件. .bai ...