getter & setter
2024-09-10 01:55:41
ECMAScript 5:
setter和getter的使用方式:
1.set/get:
var person = {
_name: '',
get name() { return this._name },
set name(n) { this._name = n }
} // 测试
person.name // ''
person.name = 'john' // 'john', 此时 person._name 也变成了 'john'
2.Object.defineProperty
var person = {}
var name = ''
Object.defineProperty(person, 'name', {
configurable: true,
enumerable: true,
get: function() {
return name
},
set: function(n) {
name = n
}
}) // 测试
person.name //''
person.name = 'john' // 'john',此时全局的 name 也变成了 'john'
对于setter和getter的使用场景:
1.私有变量
// 私有变量
var person = function() {
var _name = ''
var _age = 0
return {
get name() { return _name },
set name(n) { _name = n },
get age() { return _age },
set age(a) { _age = a }
}
}()
OR
// 私有变量
var person = function() {
var _name = ''
var _age = 0
var obj = {}
Object.defineProperty(obj, 'name', {
configurable: true,
enumerable: true,
get: function() {
return _name
},
set: function(n) {
_name = n
}
})
Object.defineProperty(obj, 'age', {
configurable: true,
enumerable: true,
get: function() {
return _age
},
set: function(a) {
_age = a
}
})
return obj
}()
2.数据绑定 (MVxx等框架的原理)
模板中每个指令/数据绑定都有一个对应的 watcher 对象,在计算过程中它把属性记录为依赖。之后当依赖的 setter 被调用时,会触发 watcher 重新计算 ,也就会导致它的关联指令更新 DOM
贴一张vue的追踪数据的图:
最新文章
- NGUI学习笔记(一)UILabel介绍
- alias指令:设置命令别名
- C++自学计划
- 【BZOJ-1176&;2683】Mokia&;简单题 CDQ分治
- Python快速上手JSON指南
- 代码风格与树形DP
- JS瀑布流布局模式(2)
- PHP之session相关实例教程与经典代码
- Commons Codec - 常见的编码解码
- 多版本uboot命令行分析
- 使用 trait 时报PHP Parse error: syntax error, unexpected 'use' (T_USE) 这个错误
- 基于实际项目的SQL学习总结
- 笔记-JDBC和commons-dbutils
- Ubuntu16.04下安装elasticsearch+kibana实现php客户端的中文分词
- SQL Server 数据导入Mysql具体教程
- MySQL 复习笔记
- hdu1866 A + B forever!(面积并)题解
- C常用问题
- mysql转型
- Exp3 免杀原理与实践 20164321 王君陶