詳解VUE中的Proxy代理
Proxy 是ES6中提供的一個(gè)非常強(qiáng)大的功能,可以用來代理另一個(gè)對(duì)象,從而攔截、監(jiān)視并修改這個(gè)對(duì)象的各種操作
首先是Proxy()的參數(shù):
- arget:被代理的對(duì)象。
- handler:被代理對(duì)象上的自定義行為,也就是對(duì)arget進(jìn)行處理的地方
handler處理函數(shù)一都有:
- get(target, propKey, receiver):攔截對(duì)象屬性的讀取操作。
- set(target, propKey, value, receiver):攔截對(duì)象屬性的設(shè)置操作,返回一個(gè)布爾值
- has(target, propKey):攔截 propKey in proxy 操作,返回一個(gè)布爾值
- deleteProperty(target, propKey):攔截對(duì)象屬性的刪除操作,返回一個(gè)布爾值
- apply(target, object, args):攔截 Proxy 實(shí)例作為函數(shù)調(diào)用的操作。
- construct(target, args, newTarget):攔截 Proxy 實(shí)例作為構(gòu)造函數(shù)調(diào)用的操作,返回一個(gè)對(duì)象
- ......
下面對(duì)get函數(shù)進(jìn)行簡(jiǎn)單的演示:
let arr = [123,"ac","你好"] arrPro = new Proxy(arr,{ get(target,prop){ // target 代表被代理的數(shù)組,也就是 [123,"ac","你好"] console.log(target) // prop 表示要訪問的屬性,也就是 0 console.log(prop) return prop in target ? target[prop] : 'error' } }) console.log(arrPro[0])
下面對(duì)set函數(shù)進(jìn)行簡(jiǎn)單的演示:
let arr = [] let arrPro = new Proxy(arr,{ set(target,prop,val){ if(typeof val === "number"){ target[prop] = val return true }else{ return false } } }) arrPro.push(5) console.log(arr) //[5]
下面對(duì)has函數(shù)進(jìn)行簡(jiǎn)單的演示:
let range = { start:1, end:5 } range = new Proxy(range,{ has(target,prop){ return prop >= target.start && prop <= target.end } }) console.log(2 in range) // true console.log(6 in range) // false
get、set、deleteProperty小集合:
let user = { name: 'ac', age: 12, _password: 'xxx' } user = new Proxy(user, { get(target, prop) { if (prop.startsWith('_')) { throw new Error('不可訪問') } else { return target[prop] } }, set(target, prop, val) { if (prop.startsWith('_')) { throw new Error('不可設(shè)置') } else { target[prop] = val return true } }, deleteProperty(target, prop) { if (prop.startsWith('_')) { throw new Error('不可刪除') } else { delete target[prop] return true } } }) console.log(user.age) //12 console.log(user._password) //Error:不可訪問 user.age = 22 console.log(user.age) //22 delete user.age console.log(user.age) //undefined
下面對(duì)apply函數(shù)進(jìn)行簡(jiǎn)單的演示:
let sum = (...args) =>{ let num = 0 args.forEach(item =>{ num += item }) return num } sum = new Proxy(sum,{ apply(target,ctx,args){ return target(...args) * 2 } }) console.log(sum(2,5)) //14 console.log(sum.call(null,2,5)) //14 console.log(sum.apply(null,[2,5])) //14
下面對(duì)construct函數(shù)進(jìn)行簡(jiǎn)單的演示:
let User = class { constructor(name){ this.name = name } } User = new Proxy(User,{ construct(target,args,newTarget){ console.log("代理攔截") //代理攔截 return new target(...args) //User {name: 'ac'} } }) console.log(new User('ac'))
vue3中就是用Proxy實(shí)現(xiàn)的雙向數(shù)據(jù)綁定
到此這篇關(guān)于Proxy代理對(duì)象詳解的文章就介紹到這了,更多相關(guān)Proxy代理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解Vue項(xiàng)目在其他電腦npm run dev運(yùn)行報(bào)錯(cuò)的解決方法
這篇文章主要介紹了詳解Vue項(xiàng)目在其他電腦npm run dev運(yùn)行報(bào)錯(cuò)的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-10-10VUE table表格動(dòng)態(tài)添加一列數(shù)據(jù),新增的這些數(shù)據(jù)不可以編輯(v-model綁定的數(shù)據(jù)不能實(shí)時(shí)更新)
這篇文章主要介紹了VUE table表格動(dòng)態(tài)添加一列數(shù)據(jù),新增的這些數(shù)據(jù)不可以編輯(v-model綁定的數(shù)據(jù)不能實(shí)時(shí)更新),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2020-04-04Vue.js實(shí)戰(zhàn)之組件的進(jìn)階
組件(Component)是 Vue.js 最強(qiáng)大的功能之一,之前的文章都只是用到了基本的封裝功能,這次將介紹一些更強(qiáng)大的擴(kuò)展。這篇文章主要介紹了Vue.js實(shí)戰(zhàn)之組件進(jìn)階的相關(guān)資料,需要的朋友們可以參考借鑒,下面來一起看看吧。2017-04-04vue項(xiàng)目引入本地bootstrap不生效問題及解決
這篇文章主要介紹了vue項(xiàng)目引入本地bootstrap不生效問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10利用Vue+intro.js實(shí)現(xiàn)頁(yè)面新手引導(dǎo)流程功能
在同學(xué)們使用某些網(wǎng)站的新版本頁(yè)面的時(shí)候,經(jīng)常會(huì)出現(xiàn)一個(gè)類似于新手引導(dǎo)一樣的效果,來幫助同學(xué)們更好的熟悉新版本頁(yè)面的功能和使用,這篇文章主要給大家介紹了關(guān)于如何利用Vue+intro.js實(shí)現(xiàn)頁(yè)面新手引導(dǎo)流程功能的相關(guān)資料,需要的朋友可以參考下2023-11-11