数据劫持--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采用的就是这种进行响应式处理

相关推荐
lichenyang45318 分钟前
把 demo 里的 console.log 全换成 HiLog:从 %{private} 没脱敏的困惑说起
前端
光影少年22 分钟前
组件复用:HOC、Render Props、自定义Hook 对比
前端·react.js·掘金·金石计划
Gauss松鼠会26 分钟前
【GaussDB】GaussDB SMP特性调优详解
java·服务器·前端·数据库·sql·算法·gaussdb
葬送的代码人生31 分钟前
JavaScript 数组完全指南:从入门到实战
前端·javascript·算法
用户9385156350733 分钟前
深入理解 JavaScript 同步与异步:从单线程到事件循环与 Promise
前端·javascript
搬砖的码农33 分钟前
造一个 Agent 运行时 #01:我决定开干,顺便把坑都写下来
前端·agent·ai编程
yingyima36 分钟前
深入解析:定时任务失败重试机制的底层原理与实践
前端
哈撒Ki36 分钟前
快速入门vue3与常见面试题
前端·vue.js·面试
踩着两条虫41 分钟前
VTJ.PRO v2.4.2 私有化部署与升级实操指南
前端·人工智能·低代码·架构·数据挖掘
木斯佳1 小时前
前端八股文面经大全:美团前端暑期实习一面(2026-06-08)·面经深度解析
前端