vue数据代理-Object.defineProperty
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>p11:数据代理-Object.defineProperty</title> <script type="text/javascript" src="js/vue.js"></script> </head> <body> <!-- 准备好一个容器:模板--> <script type="text/javascript"> let number = 20; let person = {//数据 name: 'hurong', } //创建vue实例 const vm = new Vue({ data: person }); //增加一个age属性,需在控制台测试 Object.defineProperty(person, 'age', { // value: number, // enumerable: true,//是否可枚举,默认false // writable: true,//是否可修改,默认false // configurable: true,//是否可删除,默认false //以上不能和get(),set()同时开启 get() { console.log('有人读取了age') return number }, set(value) { console.log('有人设置了age') number = value; } }) //数据代理:一个对像去读写另一个对像的值,效果类似于指针 let person2 = { name: 'tom' } Object.defineProperty(person2, 'name', { get() { return person.name; }, set(value) { person.name = value; } }) //data数据存储于vm._data中 vm._data===data,修改_data中的数据相当于修改data(指针效果),页面效果也会变 </script> </body> </html>
赞:(0)
踩:(0)
- 相关文章
- 初识vue
- 数据绑定:第一个vue例子
- vue模板语法
- vue数据绑定
- el与data的两种写法/延迟挂载
- vue事件及事件修饰符prevent/stop/
- vue计算属性computed
- vue(深度)监视属性watch
- vue绑定样式:class,:style
- vue条件渲染v-if/v-show
- 热门文章
- win7中将文件拷贝到虚拟机linux下
- phpexcel设置行高及列宽,背景颜色,
- rabbitmq无法启动
- intellij idea不显示git push按钮
- php7中使用mongodb的aggregate进行
- laravel页面静态化的方法
- centos7.4 64位下swoole安装及配置
- navicate连接mycat报1184错误
- curl设置超时不起作用(CURLOPT_TIM
- devops-jenkins容器为pending状态
- 好评文章
- phpexcel设置行高及列宽,背景颜色,
- php7中使用mongodb的aggregate进行
- intellij idea打开文件所在文件夹
- windows下使用MongoDB Compass Com
- win7中将文件拷贝到虚拟机linux下
- laravel 中悲观锁 & 乐观锁的使用
- 单点登录sso原理及php实现方式及de
- navicate连接mycat报1184错误
- rabbitmq无法启动
- laravel整合dingo/api方法步骤:jwt
- 我的项目
- 【github】www.github.com/hurong241
- 【码云】gitee.com/hu_rong/projects
- 【docker hub】hub.docker.com/repositories/hurong241
- 【packagist】packagist.org/users/hurong241/packages
- 站点信息
- 建站时间:2011年
- 文章数:623篇
- 浏览数:1303109