React Hooks

React Hooks是React 16.8版本后引入的新语法,借助react hooks,function组件拥有和class组件一样的能力,而且在代码量和执行效率上都超越了前者。

useState

useState()为函数组件引入了状态,接受状态的初始值作为参数,返回一个数组,数组的第一个成员是一个变量(count),指向状态的当前值;第二个成员是一个函数(setCount),用来更新状态。setCount的接受一个参数,推荐传入函数而不是变量作为参数,可以避免产生不必要bug。如setCount((count) => count + 1)而不是直接setCount(count + 1)

import React, { useState } from 'react'

export default () => {
  const [count, setCount] = useState(0)
  return (
    <div>
      <div>Your count:{count}</div>
      <button onClick={() => setCount((count) => count + 1)}>Add</button>
    </div>
  )
}
useEffect

useEffect()是一个函数,第一个参数是回调函数,第二个参数可以是state、空或者常量。如果为空,那么任何state发生变化时都会执行回调函数;如果是常量,回调函数仅执行一次;如果为state,那么只有当这个state发生变化时才会执行回调函数。

依赖变化作用

import React, { useState, useEffect } from 'react'

// eslint-disable-next-line import/no-anonymous-default-export
export default () => {
  const [count, setCount] = useState(0)
  useEffect(() => {
    console.log(`You clicked ${count}.`)
  })
  return (
    <div>
      <div>Your count:{count}</div>
      <button onClick={() => setCount((count) => count + 1)}>Add</button>
    </div>
  )
}

回调函数也可以写在外面

import React, { useState, useEffect } from 'react'

function log(count) {
  console.log(`You clicked ${count}.`)
}
export default () => {
  const [count, setCount] = useState(0)
  useEffect(log.bind(null, count))
  return (
    <div>
      <div>Your count:{count}</div>
      <button onClick={() => setCount((count) => count + 1)}>Add</button>
    </div>
  )
}

依赖空变化作用

import React, { useState, useEffect } from 'react'

export default () => {
  const [count, setCount] = useState(0)
  useEffect(() => {
    console.log(`You clicked ${count}.`)
  }, [])
  return (
    <div>
      <div>Your count:{count}</div>
      <button onClick={() => setCount((count) => count + 1)}>Add</button>
    </div>
  )
}

依赖state作用

import React, { useState, useEffect } from 'react'

export default () => {
  const [count, setCount] = useState(0)
  useEffect(() => {
    console.log(`You clicked ${count}.`)
  }, [count])
  return (
    <div>
      <div>Your count:{count}</div>
      <button onClick={() => setCount((count) => count + 1)}>Add</button>
    </div>
  )
}

使用总结:如果回调函数中使用到某个state,就在数组中声明这个state。

下面看一个定时器的例子

import React, { useState, useEffect } from 'react'

function useInterval(callback, time) {
  useEffect(() => {
    const I = setInterval(callback, time)
    return () => {
      clearInterval(I)
    }
  }, [])
}

export default () => {
  const [count, setCount] = useState(0)
  useInterval(() => {
    // setCount(count + 1) 
    setCount((count) => count + 1)
  }, 1000)
  return (
    <div>
      <div>Your count:{count}</div>
      <button onClick={() => setCount((count) => count + 1)}>Add</button>
    </div>
  )
}

输出count的值每秒增加1。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1.useState 使用单个 state 变量还是多个 state 变量useState 的出现,让我们可以使用...
    MelousJ阅读 3,954评论 0 0
  • Hook 是 React 16.8 的新增特性。它可以让你在不编写 class 的情况下使用 state 以及其他...
    mora__阅读 3,826评论 0 0
  • 什么是hooks? hooks 是 react 在16.8版本开始引入的一个新功能,它扩展了函数组件的功能,使得函...
    JoeRay61阅读 3,696评论 0 0
  • React Hooks Hook 是 16.8新增特性。 hooks 优势 能优化类组件的三大问题 能在无需修改组...
    Vincent_cy阅读 4,221评论 0 0
  • 渐变的面目拼图要我怎么拼? 我是疲乏了还是投降了? 不是不允许自己坠落, 我没有滴水不进的保护膜。 就是害怕变得面...
    闷热当乘凉阅读 9,837评论 0 13

友情链接更多精彩内容