数据劫持--Object.definePropertie

1、什么是Object.definePropertie

Object.defineProperty() 是JavaScript中的一个方法,它用于直接在对象上定义新属性,或者修改一个对象的现有属性,并返回这个对象。

2、Object.defineProperty() 方法接受三个参数:

  1. obj:要定义属性的对象。

  2. prop:要定义或修改的属性的名称或Symbol。

  3. descriptor:将被定义或修改的属性的描述符。

    数据描述符是一个具有值的属性,该值可能是可写的,也可能不是。数据描述符具有以下可选键值:

  • value:该属性的值。默认值为 undefined
  • writable:当且仅当该属性的 value 可以改变时为 true。默认为 false
  • enumerable:当且仅当该属性出现在对象的枚举属性中时为 true。默认为 false
  • configurable:当且仅当该属性的描述符能够被改变以及该属性能够从对应的对象中被删除时为 true。默认为 false
javascript 复制代码
 
function defineProperty() {
    var _obj={};
    var a=1;
    
    Object.defineProperties(_obj,{
        a:{
          get(){
               return  'get' + a ;//var的a
                },
            set(newVal){
                a=newVal
                console.log('set的newVal',newVal)
                }
           }
    })
return _obj
}
var obj = defineProperty();
console.log(obj.a) //走的get方法获取
obj.a=199 // 走的set方法进行修改

数据劫持:把一个对象里的属性进行可配置可写 可枚举,通过get set方法对取值 存取值进行逻辑上的扩展

取一个值的时候 先走get方法 当设置一个值的时候先看set方法的逻辑

vue2采用的就是这种进行响应式处理

相关推荐
chxii1 分钟前
在 IIS 中实现 SSL 证书的自动续期
前端
周星星日记8 分钟前
vue3中静态提升和patchflag实现
前端·vue.js·面试
橘子编程15 分钟前
React 19 全栈开发实战指南
前端·react.js·前端框架
DanCheOo16 分钟前
AI Streaming 架构:从浏览器到服务端的全链路流式设计
前端·agent
我是小趴菜22 分钟前
前端如何让图片、视频、pdf等文件在浏览器直接下载而非预览
前端
cg3326 分钟前
开源项目自动化:用 GitHub Actions 让每个 Issue 都被温柔以待
前端
haierccc36 分钟前
Win7、2008R2、Win10、Win11使用FLASH的方法
前端·javascript·html
We་ct39 分钟前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
柠檬味的Cat42 分钟前
使用腾讯云COS作为WordPress图床的实践
前端·github·腾讯云
Hilaku1 小时前
卷AI、卷算法、2026 年的前端工程师到底在卷什么?
前端·javascript·面试