VUE中的Proxy代理怎么应用

其他教程   发布日期:2025年03月07日   浏览次数:125

这篇文章主要介绍了VUE中的Proxy代理怎么应用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇VUE中的Proxy代理怎么应用文章都会有所收获,下面我们一起来看看吧。

Proxy 是ES6中提供的一个非常强大的功能,可以用来代理另一个对象,从而拦截、监视并修改这个对象的各种操作

首先是Proxy()的参数:

  • arget:被代理的对象。

  • handler:被代理对象上的自定义行为,也就是对arget进行处理的地方

handler处理函数一都有:

  • get(target, propKey, receiver):拦截对象属性的读取操作。

  • set(target, propKey, value, receiver):拦截对象属性的设置操作,返回一个布尔值

  • has(target, propKey):拦截 propKey in proxy 操作,返回一个布尔值

  • deleteProperty(target, propKey):拦截对象属性的删除操作,返回一个布尔值

  • apply(target, object, args):拦截 Proxy 实例作为函数调用的操作。

  • construct(target, args, newTarget):拦截 Proxy 实例作为构造函数调用的操作,返回一个对象

  • ......

下面对get函数进行简单的演示:

  1. let arr = [123,"ac","你好"]
  2. arrPro = new Proxy(arr,{
  3. get(target,prop){
  4. // target 代表被代理的数组,也就是 [123,"ac","你好"]
  5. console.log(target)
  6. // prop 表示要访问的属性,也就是 0
  7. console.log(prop)
  8. return prop in target ? target[prop] : 'error'
  9. }
  10. })
  11. console.log(arrPro[0])

下面对set函数进行简单的演示:

  1. let arr = []
  2. let arrPro = new Proxy(arr,{
  3. set(target,prop,val){
  4. if(typeof val === "number"){
  5. target[prop] = val
  6. return true
  7. }else{
  8. return false
  9. }
  10. }
  11. })
  12. arrPro.push(5)
  13. console.log(arr) //[5]

下面对has函数进行简单的演示:

  1. let range = {
  2. start:1,
  3. end:5
  4. }
  5. range = new Proxy(range,{
  6. has(target,prop){
  7. return prop >= target.start && prop <= target.end
  8. }
  9. })
  10. console.log(2 in range) // true
  11. console.log(6 in range) // false

get、set、deleteProperty小集合:

  1. let user = {
  2. name: 'ac',
  3. age: 12,
  4. _password: 'xxx'
  5. }
  6. user = new Proxy(user, {
  7. get(target, prop) {
  8. if (prop.startsWith('_')) {
  9. throw new Error('不可访问')
  10. } else {
  11. return target[prop]
  12. }
  13. },
  14. set(target, prop, val) {
  15. if (prop.startsWith('_')) {
  16. throw new Error('不可设置')
  17. } else {
  18. target[prop] = val
  19. return true
  20. }
  21. },
  22. deleteProperty(target, prop) {
  23. if (prop.startsWith('_')) {
  24. throw new Error('不可删除')
  25. } else {
  26. delete target[prop]
  27. return true
  28. }
  29. }
  30. })
  31. console.log(user.age) //12
  32. console.log(user._password) //Error:不可访问
  33. user.age = 22
  34. console.log(user.age) //22
  35. delete user.age
  36. console.log(user.age) //undefined

下面对apply函数进行简单的演示:

  1. let sum = (...args) =>{
  2. let num = 0
  3. args.forEach(item =>{
  4. num += item
  5. })
  6. return num
  7. }
  8. sum = new Proxy(sum,{
  9. apply(target,ctx,args){
  10. return target(...args) * 2
  11. }
  12. })
  13. console.log(sum(2,5)) //14
  14. console.log(sum.call(null,2,5)) //14
  15. console.log(sum.apply(null,[2,5])) //14

下面对construct函数进行简单的演示:

  1. let User = class {
  2. constructor(name){
  3. this.name = name
  4. }
  5. }
  6. User = new Proxy(User,{
  7. construct(target,args,newTarget){
  8. console.log("代理拦截") //代理拦截
  9. return new target(...args) //User {name: 'ac'}
  10. }
  11. })
  12. console.log(new User('ac'))

以上就是VUE中的Proxy代理怎么应用的详细内容,更多关于VUE中的Proxy代理怎么应用的资料请关注九品源码其它相关文章!