vue3中proxy的基本用法說明
更新時間:2022年05月27日 09:45:09 作者:愛生活,愛編程
這篇文章主要介紹了vue3中proxy的基本用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
vue3 proxy基本用法
新的改變
- 我們的vue3 使用proxy 來代替vue2 的 Object.defineProperty
- 效率更高,值得我們學(xué)習(xí)
基本使用
<script> var target = { name: "xiaoming", age: 18 } // handler 是一個對象 const handler = { set(target, prop, value) { let result = Reflect.set(target, prop, value) console.log("設(shè)置的操作" + result) return true; }, get(target, value) { let result = Reflect.get(target, value) console.log("獲取的的操作" + result) } } let proxy = new Proxy(target, handler); proxy.coure = "java" console.log(proxy) </script>
這個打印效果:
vue3中proxy代理
理解Proxy代理
這里模擬一個偽Vue,使用Proxy代理為響應(yīng)式
<div id='app'></div> <script> const data = { name:'hello', age:10 } const vm = new Proxy(data,{ get(target,p,receiver){ // 1.target就是代理的data對象 // 2.p 就是data中的每一個屬性(name.age) // 3.receiver就是Proxy代理對象本身 return target[p] }, set(target,p,value,receiver){ // 1.value就是最新的值 console.log('receiver:',receiver) if(taregt[p]===value) return target[p] = value document.querySelector('#app').textContent = target[p] } }) vm.name = 'hello,vue' </script>
當(dāng)我們執(zhí)行 vm.name = 'hello,vue'時,觸發(fā)了set方法,此時receiver
再次打印vm,此時,響應(yīng)的vm對象上的name變成了新的值,說明此時vm的數(shù)據(jù)變成了響應(yīng)式的了
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue路由 遍歷生成復(fù)數(shù)router-link的例子
今天小編就為大家分享一篇vue路由 遍歷生成復(fù)數(shù)router-link的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10詳解vue-router 2.0 常用基礎(chǔ)知識點之導(dǎo)航鉤子
本篇文章主要介紹了vue-router 2.0 常用基礎(chǔ)知識點之導(dǎo)航鉤子,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05vue如何解決echarts升級后本地?zé)o法啟動的問題
這篇文章主要介紹了vue如何解決echarts升級后本地?zé)o法啟動的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06基于Vue組件化的日期聯(lián)動選擇器功能的實現(xiàn)代碼
這篇文章主要介紹了基于Vue組件化的日期聯(lián)動選擇器的實現(xiàn)代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-11-11