詳解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) // falseget、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)文章
vue3中使用vuedraggable實(shí)現(xiàn)拖拽el-tree數(shù)據(jù)分組功能
這篇文章主要介紹了vue3中使用vuedraggable實(shí)現(xiàn)拖拽el-tree數(shù)據(jù)分組功能,可以實(shí)現(xiàn)單個(gè)拖拽、雙擊添加、按住ctrl鍵實(shí)現(xiàn)多個(gè)添加,或者按住shift鍵實(shí)現(xiàn)范圍添加,添加到框中的數(shù)據(jù),還能拖拽排序,需要的朋友可以參考下2024-02-02
Vue加載讀取本地txt/json等文件的實(shí)現(xiàn)方式
這篇文章主要介紹了Vue加載讀取本地txt/json等文件的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
vue雙向數(shù)據(jù)綁定知識(shí)點(diǎn)總結(jié)
這篇文章主要介紹了vue雙向數(shù)據(jù)綁定的原理以及知識(shí)點(diǎn)總結(jié),并做了代碼實(shí)例分析,有需要的朋友參考下。2018-04-04
Vue Router根據(jù)后臺(tái)數(shù)據(jù)加載不同的組件實(shí)現(xiàn)
本文主要介紹了根據(jù)用戶所購(gòu)買服務(wù)的不同,有不同的頁(yè)面展現(xiàn)。文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
webpack+vue.js實(shí)現(xiàn)組件化詳解
vue的開發(fā)體驗(yàn)還是比較愉悅的。首先文檔非常友好,所以上手會(huì)比較快。其次,配合webpack和vue-loader,每個(gè)頁(yè)面都是一個(gè).vue文件,寫起來很方便。所以很適合做組件化開發(fā),這篇文章我們就來一起看看webpack+vue.js如何實(shí)現(xiàn)組件化。2016-10-10
vue圓形進(jìn)度條環(huán)形進(jìn)度條組件內(nèi)部顯示圖片示例
這篇文章主要為大家介紹了vue圓形進(jìn)度條環(huán)形進(jìn)度條組件內(nèi)部顯示圖片示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11

