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;
相关推荐
迷雾漫步者1 小时前
Flutter组件————FloatingActionButton
前端·flutter·dart
向前看-2 小时前
验证码机制
前端·后端
燃先生._.3 小时前
Day-03 Vue(生命周期、生命周期钩子八个函数、工程化开发和脚手架、组件化开发、根组件、局部注册和全局注册的步骤)
前端·javascript·vue.js
高山我梦口香糖4 小时前
[react]searchParams转普通对象
开发语言·前端·javascript
m0_748235244 小时前
前端实现获取后端返回的文件流并下载
前端·状态模式
m0_748240255 小时前
前端如何检测用户登录状态是否过期
前端
black^sugar5 小时前
纯前端实现更新检测
开发语言·前端·javascript
寻找沙漠的人5 小时前
前端知识补充—CSS
前端·css
GISer_Jing6 小时前
2025前端面试热门题目——计算机网络篇
前端·计算机网络·面试