react函数式组件每次setstate内部变量重新赋值问题

react函数式组件每次setstate内部变量重新赋值问题

背景

react函数式组件每次setstate内部变量重新初始化赋值问题,导致不能够对变量正常赋值和读值。

bash 复制代码
const App: FC = ({ }) => {
  let a:string = '0'
  const [status, setStatus] = useState<string>('')
  console.log(a)
  return (
   <div 
    style={{
      width: '100px',
      height: '100px',
      background: 'red'
    }} 
    onClick={()=>{
      a = '1'
      setStatus('-')
    }}></div>
  )
}

这个时候首先依次打印的是 '0'、'0'因为当setStatus('-'')的时候,函数式组件会重新渲染内部,这样内部变量的声明也会再次执行,此时 a 又变成了 '0'。

解决办法

在函数外部声明此变量即可,这样就能够对变量正常赋值和读值了。

bash 复制代码
let a:string = '0'
const App: FC = ({ }) => {
  const [status, setStatus] = useState<string>('')
  console.log(a)
  return (
   <div 
    style={{
      width: '100px',
      height: '100px',
      background: 'red'
    }} 
    onClick={()=>{
      a = '1'
      setStatus('-')
    }}></div>
  )
}

如果需要再函数内部初始化值,可以现在外部声明变量,然后利用effect初始化值。

bash 复制代码
let a:string
const App: FC = ({ }) => {
  
  const [status, setStatus] = useState<string>('')
  useEffect(()=>{
    a = '0'
  },[])
  console.log(a)
  return (
   <div 
    style={{
      width: '100px',
      height: '100px',
      background: 'red'
    }} 
    onClick={()=>{
      a = '1'
      setStatus('-')
    }}></div>
  )
}
export default App;
相关推荐
parade岁月6 分钟前
nuxt和vite使用环境比变量对比
前端·vite·nuxt.js
小帆聊前端9 分钟前
Lodash 深度解读:前端数据处理的效率利器,从用法到原理全拆解
前端·javascript
Harriet嘉27 分钟前
解决Chrome 140以上版本“此扩展程序不再受支持,因此已停用”问题 axure插件安装问题
前端·chrome
FuckPatience32 分钟前
前端Vue 后端ASP.NET Core WebApi 本地调试交互过程
前端·vue.js·asp.net
Kingsdesigner37 分钟前
从平面到“货架”:Illustrator与Substance Stager的包装设计可视化工作流
前端·平面·illustrator·设计师·substance 3d·平面设计·产品渲染
一枚前端小能手1 小时前
🔍 那些不为人知但是好用的JS小秘密
前端·javascript
屿小夏1 小时前
JSAR 开发环境配置与项目初始化全流程指南
前端
微辣而已1 小时前
next.js中实现缓存
前端
北城以北88881 小时前
Vue-- Axios 交互(二)
javascript·vue.js·交互
Dcc1 小时前
纯 css 实现前端主题切换+自定义方案
前端·css