vue中的computed、watch(immediate、deep)区别

2024-05-16 12:32

本文主要是介绍vue中的computed、watch(immediate、deep)区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • vue中的computed
    • vue中的watch
    • vue实例computed和watch比较
    • watch中的immediate、deep属性

vue中的computed

注意:vue实例中data中的属性名不能和methods、computed中的属性名重名。

computed是vue实例中的计算属性,存在缓存机制,只有它所依赖的属性值发生变化才会重新计算,否则默认走缓存。这样节省性能。

当一个属性依赖多个属性或多个属性的变化会影响另一个属性时,这个属性可以放在computed中进行处理。

当一个属性依赖多个属性时一般可以采用computed方式,当该属性依赖的其他属性发生变化时,会立即调用该属性的get方法重新计算当前的属性值并重新渲染页面。

一般放在computed中属性可以为其添加get和set方法。如果只需要对该属性设置get方法可以简写。

computed与methods的区别:computed是计算属性,默认走缓存,当依赖的属性发生变化,就会执行对应的getter方法,如果多次访问同一个属性不需要多次执行该函数,它会走缓存。但是methods中定义的函数一般是在调用时执行,不存在缓存机制。

<div id="app"><!-- 当input点击时,执行的事件函数获取的还是checkbox框没有被点击前的值,所以此处要用change事件,不能使用click事件 --><input type="checkbox" v-model="selectAll">全选{{selectAll}}<br/><!--上面代码中虽然获取了两次selectAll的值,但是实际代码执行时只执行了一次selectAll的get方法,因为computed计算属性默认走缓存--><ul><li v-for="a in arr"><input type="checkbox" v-model="a.isSelected">{{a.name}}</li></ul>
</div>
<script src="node_modules/vue/dist/vue.js"></script>
<script>let vm = new Vue({el: "#app",//元素选择器data: {//data中的属性不能和methods、computed中重名arr:[{isSelected:true,name:"手机"},{isSelected:false,name:"电脑"}]},computed:{selectAll:{get(){// 函数中this指向当前实例,当这个get函数变为箭头函数时this指向window,此时可以给这个箭头函数传递一个形参,该形参就是vue实例return this.arr.

这篇关于vue中的computed、watch(immediate、deep)区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/994917

相关文章

分辨率三兄弟LPI、DPI 和 PPI有什么区别? 搞清分辨率的那些事儿

《分辨率三兄弟LPI、DPI和PPI有什么区别?搞清分辨率的那些事儿》分辨率这个东西,真的是让人又爱又恨,为了搞清楚它,我可是翻阅了不少资料,最后发现“小7的背包”的解释最让我茅塞顿开,于是,我... 在谈到分辨率时,我们经常会遇到三个相似的缩写:PPI、DPI 和 LPI。虽然它们看起来差不多,但实际应用

GORM中Model和Table的区别及使用

《GORM中Model和Table的区别及使用》Model和Table是两种与数据库表交互的核心方法,但它们的用途和行为存在著差异,本文主要介绍了GORM中Model和Table的区别及使用,具有一... 目录1. Model 的作用与特点1.1 核心用途1.2 行为特点1.3 示例China编程代码2. Tab

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

Nginx指令add_header和proxy_set_header的区别及说明

《Nginx指令add_header和proxy_set_header的区别及说明》:本文主要介绍Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价... 目录Nginx指令add_header和proxy_set_header区别如何理解反向代理?proxy

Java中&和&&以及|和||的区别、应用场景和代码示例

《Java中&和&&以及|和||的区别、应用场景和代码示例》:本文主要介绍Java中的逻辑运算符&、&&、|和||的区别,包括它们在布尔和整数类型上的应用,文中通过代码介绍的非常详细,需要的朋友可... 目录前言1. & 和 &&代码示例2. | 和 ||代码示例3. 为什么要使用 & 和 | 而不是总是使

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程

Spring中@RestController和@Controller的使用及区别

《Spring中@RestController和@Controller的使用及区别》:本文主要介绍Spring中@RestController和@Controller的使用及区别,具有很好的参考价... 目录Spring中@RestController和@Controller使用及区别1. 基本定义2. 使

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处

Python实现html转png的完美方案介绍

《Python实现html转png的完美方案介绍》这篇文章主要为大家详细介绍了如何使用Python实现html转png功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 1.增强稳定性与错误处理建议使用三层异常捕获结构:try: with sync_playwright(