码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • React 把useState变成响应式 ,今天又可以早点下班了


    Ⅰ、前言

    • 我们知道 React 中 , 要想修改 「状态」 => 必须要
    • 「state , setState」 = useState() 中
    • 「setState」 去修改 => 「state」
    • 那么如果用 Proxy => 去改造 useState,那么 「摸鱼的时间」又增加啦 ?

    在这里插入图片描述

    Ⅱ、proxy 改造 useState

    • 首先我们直接修改状态,页面是无法直接更新的;
    • 但是 proxy ,可以监听到;
    • 监听到的同时,再触发 setState => 修改 setState
    • 同时再次赋予 proxy ,让下一次 proxy 正常监听到;

    下面我们实例去看 👇

    改造 👇
    export default function  Reactive(obj) {
      const [value, setValue] = useState(setProxy(obj))
      function setProxy(value) {
    	return new Proxy( value ,{
    		get:Reflect.get,
    		set(proxy,key,value,reciver){
    			setValue(proxy)
    			return Reflect.set(proxy,key,value,reciver)
    		}
    	})
      }
      return value
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    使用 👇
    import  useReactive from './proxyState'
    export default function Index() {
      const obj = useReactive({ num: 0 })
      return (
        <div>
    		<button onClick={()=>{ obj.num-- }} >减少</button>
    		<span> { obj.num } </span>
    		<button onClick={()=>{ obj.num++ }} >增加</button>
    	</div>
      )
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 直接修改 , 让 proxy 监听自动 setState ;
    优势👇
    import  useReactive from './proxyState'
    export default function Index() {
      const [state, setState] = useState({ num:0 })
      const state2 = useReactive({ num: 0 })
       
      function add(){
    	setState(
    		{ num: state.num + 1  }, 
    		(res) => {   console.log('当前最新的值为', res.num)
    	})
      	
      	state2.num++
      	console.log('当前最新的值为',  state2.num2)
      }
      // ...
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • useState 必须在 callback 回调函数里才能获取最新状态;
    • 如果 setState 后面拿去 state 则还是之前的值;
    • 改造后的获取则,会走 proxy 的 get 总是为最新,
    • 避免了setState 的 callback 回调函数嵌套问题;
    缺陷 👇
    • 只能监听对象的 「第一层属性」 , 对于深层的属性变化是没法监听到的;
    • 如果需要监听深层,需要递归 proxy ,可能对资源消耗过大;
  • 相关阅读:
    MIT 6.5840(6.824) Lab3:Raft 设计实现
    ArcGIS教程——ArcGIS工具-按线分割面
    混合云存储点燃万亿自动驾驶市场,加速产品落地
    kotlin基础教程:<5>集合与数组
    vue与react,angular的区别
    ​ 2023年APP备案操作教程 阿里云APP备案试列 APP公钥sha1签名获取方法阿里云新增APP备案操作教程西部数码、腾讯云、新网、等等其他域名备案信息系统操作类似;核心要点:A,域
    网络安全之了解安全托管服务(MSS)
    firefly-rk3399开发板100篇 之 002 学习firefly-rk3399 wiki中gpio操作 之 打开debug口的kernel log
    ★【删除二叉搜索数节点】【递归】Leetcode 450. 删除二叉搜索树中的节点
    Spring Boot 整合 Camunda 实现工作流
  • 原文地址:https://blog.csdn.net/weixin_42232622/article/details/132638531
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号