Proxy应用场景

目录

 场景一 属性校验

 场景二 实现vue3的响应式原理

 场景三 proxy实现私有属性


场景一 属性校验

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        class Person{
            constructor(){
                this.name=''
                this.age=12
                return validator(this,personValidator)
            }
        }
        const personValidator = {
            name(val){
                 return typeof val==='string'
            },
            age(val){
                return typeof val==='number' && val>18
            }
        }

        function validator(target,validator){
            return new Proxy(target, {
                validator1:validator,
                set(target,key,value){
                    if(target.hasOwnProperty(key)){
                        let v=this.validator1[key]
                        if(v(value)){
                            return Reflect.set(target,key,value)
                        }else{
                            throw new Error(`不能设置${key}属性值为${value}`)
                        }
                    }else{
                        throw new Error(`不存在${key}属性`)
                    }
                }
            })
        }
        let p1 = new Person()
        p1.name='橘子'
        // p1.sex='msafd'
        p1.age=24
        console.log(p1);
    </script>
</body>
</html>

设置不存在属性

设置年龄小于18岁

 场景二 实现vue3的响应式原理

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <input type="text">
    <p></p>
    <script>
        let inpDom =document.querySelector('input')
        let pDom =document.querySelector('p')
        let obj={
            text:''
        }
        let newObj = new Proxy(obj,{
            set:function(target,key,value){
                if(target.hasOwnProperty(key)){
                    pDom.innerHTML=value
                    /* 解决直接在控制台改变文本框属性值 */
                    inpDom.value=value
                }
            }
        })
        inpDom.addEventListener('keyup',function(e){
            /* 获取文本框输入值 */
              newObj.text = e.target.value
        })
    </script>
</body>
</html>

 

 场景三 proxy实现私有属性

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
       const userInfo={
        /* 私有属性通常一—_开头 */
        _id:123,
        getAllUsers:function(){
            console.log("获取所有用户信息");
        }
       }
       const proxy = new Proxy(userInfo,{
        get:function(target,property){
            if(property[0]=='_'){
                return undefined
            }
            return target[property]
        },
        set:function(target,key,value){
            if(key[0]!=='_'){
                target[key]=value
            }
        }
       })
       console.log(proxy._id);
    //    proxy._id=33
    </script>
</body>
</html>

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

stay calm~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值