前端学习案例-vue2源码解析2-数据劫持
index.js
import { initState } from "./init"; //传入对象参数 function Vue(options) { //传入options console.log(this, "this"); this._init(options); } //初始化 Vue.prototype._init = function (options) { //报错实例 var vm = this; vm.$options = options; //处理状态 initState(vm); }; export default Vue;
init.js
import proxyData from "./proxy" function initState(vm){ console.log(vm) var options=vm.$options; if(options.data){ initData(vm) } } function initData(vm){ //获取data数据 var data=vm.$options.data //访问data data=vm._data=typeof data==="function"?data.call(vm):data||{} //遍历值 for(var key in data){ proxyData(vm,'_data',key) } } export { initState }
proxy.js
function proxyData(vm,target,key){ Object.defineProperty(vm,key,{ get(){ console.log(vm[target][key],"列表数据") return vm[target][key] }, Set(newValue){ vm[target][key]=newValue } }) } export default proxyData
分类:
前端-核心研究
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!