| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> Vue监视属性与计算属性 -> 正文阅读 |
|
[JavaScript知识库]Vue监视属性与计算属性 |
????????本周我们开始学习Vue,最近学习的内容中感觉监视属性和计算属性需要重点区别一下。 ? ? ? ? 监视属性:????????????????1、当被监视的属性发生变化时,回调函数自动调用,进行相关操作 ????????????????2、监视属性必须存在,才能监视,不存在也不会报错 ????????????????3、监视的两种方法: ????????????????????????1)new Vue时传入watch配置 ????????????????????????2)通过vm.$watch监视 ???????????注:immediate:false决定初始时是否调用监视属性中相关函数,默认是false不调用,true为调用。deep:true决定是否深度监视,true为深度监视。为什么要设置深度监视呢?因为Vue中watch默认不监测对象内部值的改变(一层),配置deep:true可以监测对象内部值改变(多层),Vue自身可以监测对象内部值的改变,但Vue提供的watch默认不可以,使用watch时根据数据的具体结构,决定是否采用深度检测。 ? ? ? ? 计算属性:????????????????定义:要用的属性不存在,要通过已有的属性计算得来 ????????????????原理:底层借助了Object.defineproperty方法提供的getter和setter ????????????????get什么时候被调用: ????????????????????????1、初次读取fullName时。 ????????????????????????2、fullName所依赖的值发生变化时 ????????????????优势:与methods实现相比,内部有缓存机制(复用),效率更高,调试方便 ????????????????备注: ????????????????1、计算属性最终会出现在vm上,直接读取即可 ????????????????2、如果计算属性要被修改,那就必须写set函数去响应修改,且set中要引起计算时依赖的数据发生变化(注意这里是计算属性被修改,修改后使依赖数据发生改变时调用set(),而不是改变依赖的数据时调用set()) ????????computed和watch之间的区别:????????????????computed能完成的功能,watch都可以完成。 ????????????????watch能完成的功能,computed不一定能完成,例如:watch可以进行异步操作。 ????????????????两个重要的小原则: ? ? ? ? ? ? ? ? ? ? ? ? 1、所被Vue管理的函数,最好写成普通函数,这样this的指向才是vm或组件实例对象 ? ? ? ? ? ? ? ? ? ? ? ? 2、所有不被Vue管理的函数(定时器的回调函数、ajax的回调函数、Promise的回调函数)这样thiss的指向才是vm或组件实例对象 |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/11 17:37:17- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |