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 (
    
Your count:{count}
) }
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 (
    
Your count:{count}
) }

回调函数也可以写在外面

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 (
    
Your count:{count}
) }

依赖空变化作用

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

export default () => {
  const [count, setCount] = useState(0)
  useEffect(() => {
    console.log(`You clicked ${count}.`)
  }, [])
  return (
    
Your count:{count}
) }

依赖state作用

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

export default () => {
  const [count, setCount] = useState(0)
  useEffect(() => {
    console.log(`You clicked ${count}.`)
  }, [count])
  return (
    
Your count:{count}
) }

使用总结:如果回调函数中使用到某个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 (
    
Your count:{count}
) }

输出count的值每秒增加1。

你可能感兴趣的:(React Hooks)