当前位置: 首页 > news >正文

《WebGIS之Vue零基础教程》(5)计算属性与侦听器

1 计算属性

1) 什么是计算属性

:::info 计算属性就是基于现有属性计算后的属性

:::

2) 计算属性的作用

计算属性用于对原始数据的再次加工

3) 案例

:::warning **需求**

实现如下效果

:::

使用表达式实现
```html Document
请输入一个字符串:

反转后的字符串: {{msg.split('').reverse().join('')}}

<script>const vm = new Vue({el: '#app',data: {msg: '',},})
</script>

<h4 id="kqgQi">使用方法实现</h4>
```html
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.js"></script></head><body><!-- 需求: 实现字符串的反转eg. abc 转换成  cba --><div id="app">请输入一个字符串: <input type="text" v-model="msg" /> <br /><!-- 反转字符串的思路1. 取出字符串中的每个字符 msg.split('') 形成一个数组2. 反转数据. msg.split('').reverse() 形成一个反转数组3. 将反转数组拼接. msg.split('').reverse().join('')--><!-- 不推荐使用方法原因: 没有缓存, 每次调用方法, 代码会执行一次--><h3>反转后的字符串: {{reverseMsg()}}</h3><h3>反转后的字符串: {{reverseMsg()}}</h3><h3>反转后的字符串: {{reverseMsg()}}</h3><h3>反转后的字符串: {{reverseMsg()}}</h3><h3>反转后的字符串: {{reverseMsg()}}</h3></div><script>const vm = new Vue({el: '#app',data: {msg: '',},methods: {reverseMsg() {console.log('反转函数被执行了...')// 返回 反转后的字符串return this.msg.split('').reverse().join('')},},})</script></body>
</html>
使用计算属性实现
```html Document
请输入一个字符串:

反转后的字符串: {{reverseMsg}}

反转后的字符串: {{reverseMsg}}

反转后的字符串: {{reverseMsg}}

反转后的字符串: {{reverseMsg}}

反转后的字符串: {{reverseMsg}}

<script>const vm = new Vue({el: '#app',data: {msg: '',},computed: {// 编写一个函数, 这个函数会被做为该计算属性的getterreverseMsg() {console.log('计算属性被执行了...')// 该函数的返回值, 做为访问计算属性的结果return this.msg.split('').reverse().join('')},},})
</script>

<h3 id="kpi31">4) 特点</h3>
:::info
1. 有缓存
2. 调试方便:::<h3 id="UuqO0">5) 作业</h3>
![](https://cdn.nlark.com/yuque/0/2022/png/25807822/1654746466409-a900d15f-21e6-4709-bc4b-564f6a9f05a5.png)<h2 id="dZ1E9">2 侦听器</h2>
<h3 id="XyPpp">1) 什么是侦听器</h3>
:::info
可以通过watch配置项, 监听data中已经存在的属性的改变:::<h3 id="CIa7L">2) 语法</h3>
```javascript
watch: {// 监听data中的firstName属性firstName() {// 执行一系列的操作},
},

示例

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.global.js"></script></head><body><div id="app">姓: <input type="text" v-model="lastName" /> <br />名: <input type="text" v-model="firstName" /> <br />全名(侦听器实现): {{fullName}}</div><script>const { createApp } = Vueconst vm = createApp({data() {return {lastName: '',firstName: '',fullName: '',}},watch: {// 侦听lastName的变化, 当lastName变化时, 执行该函数lastName() {this.fullName = this.lastName + this.firstName},// 侦听firstName的变化, 当firstName变化时, 执行该函数firstName() {this.fullName = this.lastName + this.firstName},},}).mount('#app')</script></body>
</html>

3) 特点

在watch对应的回调函数中, 可以获取到`新值`和 `旧值`

示例

const vm = new Vue({el: '#app',data: {firstName: '',lastName: '',},// 使用watch这个配置项watch: {// 在watch对应的回调函数中, 可以得到新值和旧值// 对于简单数据类型, 可以获取新旧值// 对于引用数据类型, 不能获取旧值firstName(newValue, oldValue) {// 一对多: 监听某一个属性的改变, 做一系列的操作console.log('firstName改变了...')console.log('新的值:', newValue)console.log('旧的值:', oldValue)},},
})

4) 深度监听

默认情况下`watch`配置项只会对`data`中第一层的数据进行侦听.

如果第一层的数据是引用类型(如, 数组, 对象). 需要开启深度监听

示例

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.global.js"></script></head><body><div id="app">姓: <input type="text" v-model="lastName" /> <br />名: <input type="text" v-model="firstName" /> <br /><!-- 侦听器: 一因多果(关注一个已经存在的属性的改变) --><!-- 1. 如果是基本类型数据, 可以获取到新旧值2. 默认是浅层次的侦听3. 如果是引用类型, 如果需要深层次数据的改变, 开启深度侦听-->全名(侦听器实现): {{fullName}}</div><script>const { createApp } = Vueconst vm = createApp({data() {return {lastName: '',firstName: '',fullName: '',obj: { name: 'xiaoming' },}},watch: {// 侦听lastName的变化, 当lastName变化时, 执行该函数lastName(newValue, oldValue) {console.log('新的值: ', newValue)console.log('旧的值: ', oldValue)this.fullName = this.lastName + this.firstName},// 侦听firstName的变化, 当firstName变化时, 执行该函数firstName() {this.fullName = this.lastName + this.firstName},// obj() {//   console.log('obj被修改了')// },obj: {handler() {console.log('obj被修改了...')},deep: true,},},}).mount('#app')</script></body>
</html>

5) 回调执行的时机

:::tips 默认情况下

watch在DOM更新之前调用. 得到的是 DOM更新之前的数据

:::

可以通过flush: 'post'设置在DOM更新之后调用回调

示例

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.global.js"></script></head><body><div id="app">{{msg}}</div><script>const { createApp } = Vueconst vm = createApp({data() {return {msg: 'hello',}},watch: {// 默认情况下. watch在DOM更新之前调用. 得到的是 DOM更新之前的数据// msg() {//   console.log(app.innerHTML)// },msg: {handler() {console.log('更新之后的DOM', app.innerHTML)},flush: 'post',},},}).mount('#app')</script></body>
</html>

3 计算属性 VS 侦听器

1. 是否会在vm实例中挂载新属性? 1. computed会 2. watch不会 2. 对应关系 1. computed是`多对一`, 可以同时监听多个值改变, 最终计算得到一个新的属性 2. watch是`一对多`, 主要监听一个属性的变化, 执行多种逻辑 3. 能否获取新旧值? 1. computed不能 2. watch能

4 综合作业

![](https://i-blog.csdnimg.cn/img_convert/90d0b1deadb5e0aff47a44340d3b36fb.png)

相关文章:

  • 如何利用CST把PCB的S参数生成Spice电路模型
  • Java常用API详解
  • Shell脚本-for循环语法结构
  • VLA 论文精读(十九)Learning Fine-Grained Bimanual Manipulation with Low-Cost Hardware
  • 深度解析之算法之分治(快排)
  • 【金仓数据库征文】——选择金仓,选择胜利
  • 区块链如何达成共识:PoW/PoS/DPoS的原理、争议与适用场景全解
  • 从线性到非线性:简单聊聊神经网络的常见三大激活函数
  • STM32MPU开发之旅:从零开始构建嵌入式Linux镜像
  • 《深入理解 AOP》
  • 【金仓数据库征文】-金仓数据库性能调优 “快准稳” 攻略:实战优化,让数据处理飞起来
  • 新闻速递丨Altair 与 Databricks 达成合作,加速数据驱动型创新
  • 银发科技:AI健康小屋如何破解老龄化困局
  • Qt知识点1『16进制数值与文本互相转换』
  • 【金仓数据库征文】- 国产化迁移实战:从Oracle到KingbaseES的平滑过渡
  • day32 学习笔记
  • C++学习之网络攻防以及信息搜索
  • MDF标准
  • 用 Python 打造打篮球字符动画!控制台彩色炫酷输出,抖音搞怪视频灵感还原
  • Dubbo负载均衡策略深度解析
  • 龚正会见巴基斯坦卡拉奇市市长穆尔塔扎·瓦哈卜、巴西圣保罗市市长里卡多·努内斯
  • 中共中央政治局召开会议,分析研究当前经济形势和经济工作,中共中央总书记习近平主持会议
  • 涉军民事案件类型日益增多,最高法新规明晰管辖争议问题
  • 帕力旦·吐尔逊已任喀什大学党委副书记、校长
  • 乌代表团与美特使在伦敦举行会谈,双方同意继续对话
  • 人民热评:大尺度色情语聊、撮合卖淫,社交APP岂止跑偏