【Vue】计算属性和监听属性

server/2024/10/22 14:09:02/

系列文章目录

第四章 计算属性和监听属性


文章目录

  • 系列文章目录
  • 一、计算属性
  • 二、监听属性
    • 1. 监听使用ref函数定义的属性
    • 2. 监听使用reactive函数定义的属性


一、计算属性

一般情况下属性都是直接定义的,但是有些属性可能是需要经过一些逻辑计算后才能得出来,那么我们可以把这类属性变成计算属性。比如以下:

<script setup>javascript">
import {ref, computed} from "vue";let width = ref(0);
let height = ref(0);let area = computed(() => {return width.value*height.value;
})
</script><template><label for="length">长:</label><input type="number" name="height" v-model="height"><label for="width">宽:</label><input type="number" name="width" v-model="width"><label for="area">面积:</label><input type="number" name="area" :value="area" readonly>
</template>

二、监听属性

属性监听功能允许我们实时追踪属性值的变化。一旦属性值发生改变,我们可以通过相关函数立即获取到新的值。根据定义属性的方法的不同,属性监听主要分为两种情况:一种是针对使用ref函数定义的属性,另一种是针对使用reactive函数定义的属性。

1. 监听使用ref函数定义的属性

对于使用ref函数定义的基本数据类型,则直接监听即可,示例代码如下:

<script setup>javascript">
import {ref, watch} from "vue";let width = ref(0);
watch(width, (newValue, oldValue) => {console.log(newValue);
})
const onUpdateWidth = () => {width += 1;
}
</script><template>
<div><p>宽度:{{ width }}</p><button @click="onUpdateWidth">修改width</button>
</div>
</template>

而对于使用ref函数定义的对象类型,如果要监听整个对象的变化,则直接监听即可:

<script setup>javascript">
import {ref, watch} from "vue";let person = ref({username: '张三',age: 18
})const onUpdateUsername = () => {person.value.username += "1"
}const onUpdateAge = () => {person.value.age += 1
}// 监听某个子属性的变化,使用getter方法
watch(() => person.value.username, (newValue, oldValue) => {console.log("new username: ", newValue);
})// 监听整个对象子属性的变化,开启深度监听
watch(person, (newValue, oldValue) => {console.log("new person: ", newValue);
}, {deep: true})
</script><template>
<div><p>用户名:{{ person.username }},年龄:{{ person.age }}</p><button @click="onUpdateUsername">修改username</button><button @click="onUpdateAge">修改age</button>
</div>
</template>

如果要监听属性下的子属性的变化,要么通过getter函数监听某个子属性,或者开启深度监听,监听所有子属性的变化:

<script setup>javascript">
import {ref, watch} from "vue";let person = ref({username: '张三',age: 18
})const onUpdateUsername = () => {person.value.username += "1"
}const onUpdateAge = () => {person.value.age += 1
}// 监听某个子属性的变化,使用getter方法
watch(() => person.value.username, (newValue, oldValue) => {console.log("new username: ", newValue);
})// 监听整个对象子属性的变化,开启深度监听
watch(person, (newValue, oldValue) => {console.log("new person: ", newValue);
}, {deep: true})
</script><template>
<div><p>用户名:{{ person.username }},年龄:{{ person.age }}</p><button @click="onUpdateUsername">修改username</button><button @click="onUpdateAge">修改age</button>
</div>
</template>

2. 监听使用reactive函数定义的属性

对于使用reactive函数定义的属性,那么默认会开启深度监听,所以不管是监听一个子属性的变化,还是监听所有子属性的变化,都无需手动开启深度监听。示例代码如下:

<script setup>javascript">
import {ref, reactive, watch} from "vue";
let university = reactive({name: '清华大学', year: 1911
})const updateUniversityName = () => {university.name = '北京大学'
}// 1. 监听一个子属性的变化
watch(() => univertisy.name, (newValue, oldValue) => {console.log('new name: ', newValue);
})// 2. 监听所有子属性的变化
watch(university, (newValue, oldValue) => {console.log(newValue);
})
</script><template>
<div><div>大学名称:{{ university.name }}</div><button @click="updateUniversityName">更换大学名称</button>
</div>
</template>


http://www.ppmy.cn/server/104654.html

相关文章

智慧园区:AI赋能下的创新应用场景探索及多场景解决方案介绍

随着人工智能&#xff08;AI&#xff09;技术的飞速发展&#xff0c;各行各业都在经历着前所未有的变革&#xff0c;智慧园区作为城市智慧化建设的重要组成部分&#xff0c;正逐步成为AI技术应用的热土。智慧园区通过集成物联网、大数据、云计算、人工智能等先进技术&#xff0…

【功能自动化】WebTours:使用unittest编写注册测试用例

环境搭建&#xff1a; 需要配置WebTours网站 代码实现&#xff1a; # 导入包 from selenium import webdriver from selenium.webdriver.support.select import Select from time import sleep import unittestdriver None class Reg(unittest.TestCase):classmethoddef se…

MySQL面试技术(分页)

SQL 常见分页方式详解 在数据库查询中&#xff0c;分页是一个常见的需求&#xff0c;不同的数据库有不同的分页方式。下面介绍几种常见的 SQL 分页方法。 一、LIMIT 和 OFFSET 分页法 这是最常见和通用的分页方式&#xff0c;适用于大多数支持 SQL 标准的关系型数据库&#…

基于单片机的肺活量检测仪设计

本设计基于STC12C5A60S2单片机的肺活量检测仪&#xff0c;包括供电模块、气流检测模块、按键模块、显示模块、语音输出模块和蓝牙模块&#xff0c;实现对肺活量的数值检测&#xff0c;并对数据进行语音播报与显示&#xff1b;用户可以通过连接蓝牙将数据发送至手机端&#xff0…

MFC 读写 Excel

在对话框头文件中导入头文件 #include "CApplication.h" #include "CRange.h" #include "CWorkbook.h" #include "CWorkbooks.h" #include "CWorksheet.h" #include "CWorksheets.h" #include "ShowData.h&…

nginx做代理 转发前端请求到后端

Nginx 作为反向代理服务器可以很好地处理代理转发的请求&#xff0c;它能够将客户端的请求转发到后端服务器&#xff0c;并将后端服务器的响应返回给客户端&#xff08;避免直接向后端发送请求&#xff0c;隐藏后端服务器地址&#xff09;。下面介绍如何配置 Nginx 进行代理转发…

不愿回流上班,离职博主们不断寻找新的“栖息地”

文 | 螳螂观察 作者 | 如意 “替大家试过了&#xff0c;不上班真的很爽。” “985本硕&#xff0c;年薪40万裸辞了。” “不干了&#xff0c;谁家好人半夜12点还在司啊&#xff01;” 标题熟悉吧&#xff1f;对&#xff0c;这拨人你一定看到了&#xff0c;说人生是旷野&am…

用Python插入SVG到PDF文档

将SVG&#xff08;可缩放矢量图形&#xff09;文件插入到PDF&#xff08;便携式文档格式&#xff09;文件中不仅能够保留SVG图像的矢量特性&#xff0c;确保图像在任何分辨率下都保持清晰&#xff0c;还能够充分利用PDF格式在跨平台文档分享方面的优势&#xff0c;使得技术文档…