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

网站后台出现乱码遨翔网站建设

网站后台出现乱码,遨翔网站建设,dedecms做网站教程,wordpress静态化链接前端vue监听 -watch 前言基本用法监听简单数据属性监听对象属性 高级用法深度监听对象即时触发监听监听计算属性 注意事项 前言 在 Vue.js 里,watch 选项可用于响应式地监听数据的变化,当被监听的数据发生改变时,就会触发相应的回调函数来执…

前端vue监听 -watch

    • 前言
    • 基本用法
      • 监听简单数据属性
      • 监听对象属性
    • 高级用法
      • 深度监听对象
      • 即时触发监听
      • 监听计算属性
    • 注意事项

前言

在 Vue.js 里,watch 选项可用于响应式地监听数据的变化,当被监听的数据发生改变时,就会触发相应的回调函数来执行特定操作。下面从基本用法、高级用法以及注意事项等方面详细讲解 watch。

基本用法

监听简单数据属性

监听一个简单的数据属性时,在 watch 对象中使用与数据属性同名的键,对应的值为一个回调函数。该 回调函数接收两个参数 :新值和旧值。

<template><div><input v-model="message" placeholder="请输入内容"><p>当前输入内容:{{ message }}</p></div>
</template><script>
export default {data() {return {message: ''};},watch: {message(newValue, oldValue) {console.log(`新值: ${newValue}, 旧值: ${oldValue}`);}}
};
</script>

在这个例子中,每当 message 的值改变时,回调函数就会被触发,同时会在控制台打印出新值和旧值。

监听对象属性

如果要监听对象的某个属性,可使用字符串形式的路径来指定要监听的属性。

<template><div><input v-model="user.name" placeholder="请输入姓名"><p>当前姓名:{{ user.name }}</p></div>
</template><script>
export default {data() {return {user: {name: ''}};},watch: {'user.name'(newValue, oldValue) {console.log(`新姓名: ${newValue}, 旧姓名: ${oldValue}`);}}
};
</script>

这里监听了 user 对象的 name 属性,当 name 改变时,会在控制台输出相应信息。

高级用法

深度监听对象

若要监听对象内部所有属性的变化,需使用深度监听,通过设置 deep: true 来实现。

<template><div><input v-model="user.name" placeholder="请输入姓名"><input v-model="user.age" placeholder="请输入年龄"><p>当前姓名:{{ user.name }}, 当前年龄:{{ user.age }}</p></div>
</template><script>
export default {data() {return {user: {name: '',age: ''}};},watch: {user: {handler(newValue, oldValue) {console.log('用户信息已更新');},deep: true}}
};
</script>

只要 user 对象的任何属性发生变化,handler 函数就会被触发。不过要注意,深度监听会遍历对象的所有属性,可能会对性能产生一定影响。

即时触发监听

有时希望 在组件挂载时就立即触发一次监听函数,可使用 immediate: true 选项。

<template><div><input v-model="message" placeholder="请输入内容"><p>当前输入内容:{{ message }}</p></div>
</template><script>
export default {data() {return {message: ''};},watch: {message: {handler(newValue, oldValue) {console.log(`新值: ${newValue}, 旧值: ${oldValue}`);},immediate: true}}
};
</script>

在这个例子中,组件挂载时就会执行一次 handler 函数。

监听计算属性

除了监听数据属性,还能监听计算属性。当计算属性依赖的数据发生变化,导致计算属性的值改变时,监听函数会被触发。

<template><div><input v-model="firstName" placeholder="请输入名字"><input v-model="lastName" placeholder="请输入姓氏"><p>全名:{{ fullName }}</p></div>
</template><script>
export default {data() {return {firstName: '',lastName: ''};},computed: {fullName() {return `${this.firstName} ${this.lastName}`;}},watch: {fullName(newValue, oldValue) {console.log(`新全名: ${newValue}, 旧全名: ${oldValue}`);}}
};
</script>

当 firstName 或者 lastName 发生变化,fullName 也会改变,此时监听函数会被触发。

注意事项

  1. 性能影响:深度监听会递归遍历对象的所有属性,当对象结构复杂时,可能会对性能造成较大影响。所以在使用深度监听时,要谨慎考虑。
  2. 旧值问题:在深度监听对象时,oldValue 和 newValue 可能指向同一个对象,因为它们都是对象的引用。如果需要对比对象的前后状态,可以在 handler 函数中进行深拷贝。
  3. 销毁监听:在组件销毁时,Vue 会自动销毁 watch 监听。但如果使用了 $watch 方法手动创建监听,需要在组件销毁前手动调用 unwatch 函数来销毁监听,避免内存泄漏。

综上所述,watch 是 Vue.js 中一个非常实用的特性,合理使用它可以方便地处理数据变化时的逻辑。

http://www.dtcms.com/wzjs/586813.html

相关文章:

  • 做网站怎样调用支付宝接口织梦映像
  • 最新网站建设合同西安计算机培训机构哪个最好
  • 代码编辑器做热点什么网站好做网站时字幕怎么做
  • 海南网站推广建设wordpress分城市访问
  • 锡盟本地网站建设wordpress+后门检查
  • 烟台做网站优化哪家好做效果图常用的网站有哪些软件
  • 淘宝网站建设违规吗做网站花都
  • 山东免费网站建设手机网站管理工具
  • 无锡网站建设上海韵茵模版网站做支付功能
  • 东莞网站排名推广找人做网站需要准备什么材料
  • 站长工具下载app品牌设计属于平面设计吗
  • 珠海网站建设怎样东莞网站建设部落
  • asp网站密码电子商务网站有哪些
  • 网站开发的职责与分工室内设计3d效果图用什么软件
  • 深圳网站建设公司佰达企业邮箱app
  • 模板网站如何快速交付给客户视频直播网站开发
  • 汕头企业建站系统模板网络规划设计师和信息系统项目管理师哪个好考
  • 做网站怎么去进行链接开发网站需要租服务器
  • 网站做调查问卷给钱的兼职免费模板下载个人简历
  • 网站后台空间30g要多少钱网站建设管理工作的意见
  • 装修公司加盟合作模式重庆网站优化网络服务
  • 当阳网站建设网站建设放在哪个费用
  • 手机网站开发需求 百度云盘自己做网站要钱吗
  • 怎么在wordpress建站网页设计论文的研究内容
  • 如何提高网站访客数聚搜济南网站建设公司
  • 网站建设课程设计心得智慧团建官网手机登录入口电脑版
  • 甘肃省建设工程安质局网站wordpress悬浮插件
  • 做国外贸易哪个网站好合肥百度seo排名
  • 苏州网站排名推广成都网站设计制作价格
  • 遵义县住房和城乡建设局网站网站建设中扒站为什么是违法的