詳解VUE中的Proxy代理
Proxy 是ES6中提供的一個非常強大的功能,可以用來代理另一個對象,從而攔截、監(jiān)視并修改這個對象的各種操作
首先是Proxy()的參數(shù):
- arget:被代理的對象。
- handler:被代理對象上的自定義行為,也就是對arget進行處理的地方
handler處理函數(shù)一都有:
- get(target, propKey, receiver):攔截對象屬性的讀取操作。
- set(target, propKey, value, receiver):攔截對象屬性的設置操作,返回一個布爾值
- has(target, propKey):攔截 propKey in proxy 操作,返回一個布爾值
- deleteProperty(target, propKey):攔截對象屬性的刪除操作,返回一個布爾值
- apply(target, object, args):攔截 Proxy 實例作為函數(shù)調用的操作。
- construct(target, args, newTarget):攔截 Proxy 實例作為構造函數(shù)調用的操作,返回一個對象
- ......
下面對get函數(shù)進行簡單的演示:
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])
下面對set函數(shù)進行簡單的演示:
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]
下面對has函數(shù)進行簡單的演示:
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('不可設置') } 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
下面對apply函數(shù)進行簡單的演示:
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
下面對construct函數(shù)進行簡單的演示:
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實現(xiàn)的雙向數(shù)據(jù)綁定
到此這篇關于Proxy代理對象詳解的文章就介紹到這了,更多相關Proxy代理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解Vue項目在其他電腦npm run dev運行報錯的解決方法
這篇文章主要介紹了詳解Vue項目在其他電腦npm run dev運行報錯的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-10-10VUE table表格動態(tài)添加一列數(shù)據(jù),新增的這些數(shù)據(jù)不可以編輯(v-model綁定的數(shù)據(jù)不能實時更新)
這篇文章主要介紹了VUE table表格動態(tài)添加一列數(shù)據(jù),新增的這些數(shù)據(jù)不可以編輯(v-model綁定的數(shù)據(jù)不能實時更新),本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2020-04-04利用Vue+intro.js實現(xiàn)頁面新手引導流程功能
在同學們使用某些網(wǎng)站的新版本頁面的時候,經(jīng)常會出現(xiàn)一個類似于新手引導一樣的效果,來幫助同學們更好的熟悉新版本頁面的功能和使用,這篇文章主要給大家介紹了關于如何利用Vue+intro.js實現(xiàn)頁面新手引導流程功能的相關資料,需要的朋友可以參考下2023-11-11