JavaScript使用Object.defineProperty方法实现双数据绑定
Object.defineProperty这个方法非常值得学习,很多mvc框架中的双向数据绑定就是通过它来实现的。
本着互联网分享精神,今天我就将我自己的见解分享给大家,希望能有所帮助。
开始使用
Object.defineProperty接收三个参数
* 目标对象
* 需要要定义的属性名或方法的名字
* 目标属性所拥有的特性 - descriptor (之后讲解下面案例不包括)
代码实例
var User = {};
Object.defineProperty(User, 'info', {
value: 123
});
console.log(User.info);
descriptor
descriptor接收6个参数
注意事项:如果使用了(value和writable)就不能使用(get和set),他们可以理解为两组参数。如果同时使用就会报错。
另外如果参数中设置configurable 又设置了value,writable,configurable,将会以value,writable,configurable中设置的值为准。
var User = {};
Object.defineProperty(User, "info", {
// value: 123, // 属性的值
// writable: false, // 默认为false 如果值为false那么属性的值就不能被重写,只能读取。
configurable: false,//默认false 如果值为false 就不能再设置或修改他的(value,writable,configurable)
enumerable: false,// 默认false 如果值为false就不能再for..in循环中遍历和 Object.keys() 中被枚举。
// 调用时不传参执行的方法
get: function () {
return 'get'
},
//调用时传参执行的方法
set: function (set) {
return set
}
});
console.log(User.info);//调用get方法输出 get
console.log(User.info = 'aaa');//调用 set 方法 输出 aaa
值的修改
注意事项: configurable=false,但只要是设置了writable 值还是会修改的,如果writable=false,那么两次输出的结果都会是123。
var User = {};
Object.defineProperty(User, "info", {
value: 123,
writable: true,
configurable: false
});
console.log(User.info); // 输出 123
User.info = 456;
console.log(User.info); // 输出 456
enumerable
注意事项如果enumerable=false,那么输出就会是一个空数组、
var User = {};
Object.defineProperty(User, "info", {
value: 123,
enumerable: true,
});
console.log(Object.keys(User)); //输出['info']
实战小案例实现双向数据绑定
html源码
<p>今天天气 : <span id='state'>晴天</span></p>
<div id="clothes"></div>
JavaScript源码
var UserInfo = {};
Object.defineProperty(UserInfo, "state", {
get: function () {
return document.getElementById('state').innerHTML;
},
set: function (nick) {
document.getElementById('state').innerHTML = nick;
}
});
Object.defineProperty(UserInfo, "clothes", {
get: function () {
return document.getElementById('clothes').innerHTML;
},
set: function (clothes) {
document.getElementById('clothes').innerHTML = clothes;
}
});
console.log(UserInfo.state); //输出晴天
UserInfo.clothes = "适合穿短袖";//修改html中的数据
JavaScript使用Object.defineProperty方法实现双数据绑定的更多相关文章
- JavaScript Object.defineProperty()方法详解
Object.defineProperty() 方法直接在一个对象上定义一个新属性,或者修改一个已经存在的属性, 并返回这个对象. 语法 Object.defineProperty(obj, prop ...
- Object.defineProperty方法 使用
Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性, 并返回这个对象. 语法: Object.defineProperty(obj, pr ...
- Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个已经存在的属性, 并返回这个对象。
Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个已经存在的属性, 并返回这个对象. 语法EDIT Object.defineProperty(obj, ...
- Vue el与data的两种写法 && Object.defineProperty方法
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="UTF-8" /> 5 & ...
- javascript之Object.defineProperty的奥妙
直切主题 今天遇到一个这样的功能: 写一个函数,该函数传递两个参数,第一个参数为返回对象的总数据量,第二个参数为初始化对象的数据.如: var o = obj (4, {name: 'xu', age ...
- Object.defineProperties()和Object.defineProperty()方法
Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性, 并返回这个对象. 语法:Object.defineProperty(obj, pro ...
- js中Object.defineProperty()方法的解释
菜菜: “老大,那个, Object.defineProperty 是什么鬼?” 假设我们有个对象 user ; 我们要给它增加一个属性 name , 我们会这么做 1 2 3 var user = ...
- ES5 Object.defineProperty 方法
先看一个例子: var o = {}; o.a = 1; // 等待于: Object.defineProperty(o, 'a', { value: 1, writable: true, confi ...
- Object.defineProperty方法
Object.defineProperty() (一次添加/修改一个属性) 用法:Object.defineProperty(obj, prop, descriptor) 方法会直接在一个对象上定义一 ...
随机推荐
- WebService 常用的设置
1.修改WebService接收长度 <binding name="IAuthServiceSoap11Binding" maxBufferSize="214748 ...
- OCP认证052考试,新加的考试题还有答案整理-23题
23.Which two are true about data dictionary and dynamic performance views (v$ views)? A) All databas ...
- CTSC2017酱油记
恩..又是一篇酱油记.. 自从SHTSC完之后都在复习地理高考..根本没有刷题.. 于是就来CTSC了..因为奇怪的实验考..APIO又不能参加..只能拿一块Fe了.. DAY0 恩..不存在DAY0 ...
- 模拟RHCSA考试环境
转载自 http://blog.51cto.com/10681635/2084794 模拟RHCSA考试环境 第1章 修改 root 密码 第2章 配置网络 第3章 设定SeLinux 第4章 ...
- sizeWithFont:的替代方法
sizeWithFont:的替代方法 -(CGFloat)changeStationWidth:(NSString *)string{ UIFont * textFont = [UIFont syst ...
- centos下部署NFS
一. NFS简介 NFS---Network File System:主要功能是通过网络让不同的linux主机系统间可以彼此共享文件和目录.NFS客户端可以通过挂载的方式将NFS服务器端共 ...
- 吴裕雄 python 机器学习——K均值聚类KMeans模型
import numpy as np import matplotlib.pyplot as plt from sklearn import cluster from sklearn.metrics ...
- thinkphp5无限极分类
public function priTree() { $data = $this->select(); return $this->_reSort($data); } // 递归对有的分 ...
- mysql 存储过程和游标
CREATE DEFINER=`root`@`localhost` PROCEDURE `NewProc`() BEGIN #Routine body goes here... DECLARE ite ...
- 「DB」数据库事务的隔离级别
*博客搬家:初版发布于 2017/04/10 00:37 原博客地址:https://my.oschina.net/sunqinwen/blog/875833 数据库事务的隔离级别 讲事务的隔离 ...