React Hooks

React Hooks是React 16.8版本后引入的新語法扰肌,借助react hooks,function組件擁有和class組件一樣的能力熊杨,而且在代碼量和執(zhí)行效率上都超越了前者曙旭。

useState

useState()為函數(shù)組件引入了狀態(tài),接受狀態(tài)的初始值作為參數(shù)晶府,返回一個數(shù)組桂躏,數(shù)組的第一個成員是一個變量(count),指向狀態(tài)的當前值川陆;第二個成員是一個函數(shù)(setCount)剂习,用來更新狀態(tài)。setCount的接受一個參數(shù)较沪,推薦傳入函數(shù)而不是變量作為參數(shù)鳞绕,可以避免產(chǎn)生不必要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()是一個函數(shù)尸曼,第一個參數(shù)是回調(diào)函數(shù)们何,第二個參數(shù)可以是state、空或者常量控轿。如果為空冤竹,那么任何state發(fā)生變化時都會執(zhí)行回調(diào)函數(shù);如果是常量茬射,回調(diào)函數(shù)僅執(zhí)行一次鹦蠕;如果為state,那么只有當這個state發(fā)生變化時才會執(zhí)行回調(diào)函數(shù)在抛。

依賴變化作用

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>
  )
}

回調(diào)函數(shù)也可以寫在外面

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>
  )
}

使用總結(jié):如果回調(diào)函數(shù)中使用到某個state片部,就在數(shù)組中聲明這個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霜定。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末档悠,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子望浩,更是在濱河造成了極大的恐慌辖所,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件磨德,死亡現(xiàn)場離奇詭異缘回,居然都是意外死亡,警方通過查閱死者的電腦和手機典挑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進店門酥宴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人您觉,你說我怎么就攤上這事拙寡。” “怎么了琳水?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵肆糕,是天一觀的道長。 經(jīng)常有香客問我在孝,道長诚啃,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任私沮,我火速辦了婚禮始赎,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘仔燕。我一直安慰自己造垛,他們只是感情好,可當我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布涨享。 她就那樣靜靜地躺著筋搏,像睡著了一般。 火紅的嫁衣襯著肌膚如雪厕隧。 梳的紋絲不亂的頭發(fā)上奔脐,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天,我揣著相機與錄音吁讨,去河邊找鬼髓迎。 笑死,一個胖子當著我的面吹牛建丧,可吹牛的內(nèi)容都是我干的排龄。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼翎朱,長吁一口氣:“原來是場噩夢啊……” “哼橄维!你這毒婦竟也來了尺铣?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤争舞,失蹤者是張志新(化名)和其女友劉穎凛忿,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體竞川,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡店溢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了委乌。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片床牧。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖遭贸,靈堂內(nèi)的尸體忽然破棺而出戈咳,到底是詐尸還是另有隱情,我是刑警寧澤革砸,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布除秀,位于F島的核電站,受9級特大地震影響算利,放射性物質(zhì)發(fā)生泄漏册踩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一效拭、第九天 我趴在偏房一處隱蔽的房頂上張望暂吉。 院中可真熱鬧,春花似錦缎患、人聲如沸慕的。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽肮街。三九已至,卻和暖如春判导,著一層夾襖步出監(jiān)牢的瞬間嫉父,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工眼刃, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留绕辖,地道東北人。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓擂红,卻偏偏與公主長得像仪际,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 1.useState 使用單個 state 變量還是多個 state 變量useState 的出現(xiàn)树碱,讓我們可以使用...
    MelousJ閱讀 556評論 0 0
  • Hook 是 React 16.8 的新增特性肯适。它可以讓你在不編寫 class 的情況下使用 state 以及其他...
    mora__閱讀 587評論 0 0
  • 什么是hooks? hooks 是 react 在16.8版本開始引入的一個新功能,它擴展了函數(shù)組件的功能赴恨,使得函...
    JoeRay61閱讀 557評論 0 0
  • React Hooks Hook 是 16.8新增特性疹娶。 hooks 優(yōu)勢 能優(yōu)化類組件的三大問題 能在無需修改組...
    Vincent_cy閱讀 679評論 0 0
  • 漸變的面目拼圖要我怎么拼惑淳? 我是疲乏了還是投降了? 不是不允許自己墜落饺窿, 我沒有滴水不進的保護膜歧焦。 就是害怕變得面...
    悶熱當乘涼閱讀 4,246評論 0 13