黄视频网站在线免费观看-黄视频网站在线看-黄视频网站在线观看-黄视频网站免费看-黄视频网站免费观看-黄视频网站免费

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 創建一個簡單的React自定義鉤子

創建一個簡單的React自定義鉤子

來源:千鋒教育
發布人:syq
時間: 2022-09-14 17:18:48 1663147128

  有關如何創建簡單的 React 自定義鉤子的教程。在編寫 React 函數式組件時,如果我們想重用組件的部分邏輯,我們可以考慮編寫自定義 Hooks。

React自定義鉤子

  首先,讓我們來看看 React 鉤子。鉤子只是 JavaScript 函數,但是在 React 中使用它們時,你需要遵循規則:

  僅在頂層調用鉤子

  僅從 React 函數調用鉤子

   第一點與 React Hook 的實現原理有關。當函數組件第一次執行時,react分配一個對象,當一個接一個地調用鉤子時,獲得的結果依次放入有序表中,然后存儲在對象中。

  對于后續的執行,這些鉤子的執行順序必須相同,以便比較依賴關系并與先前渲染的狀態進行比較。

  如果鉤子出現在循環、條件或嵌套函數中...不能保證鉤子的執行順序不會保持不變。

  第二點意味著你應該總是從 React 函數組件調用鉤子,而不是類組件或常規的 JavaScript 函數,但如果它是一個自定義 Hook,那么從中調用鉤子也是合法的。

  自定義鉤子是具有唯一命名約定的 JavaScript 函數,該約定要求以函數名稱開頭 ,并且能夠調用其他鉤子。use

  這聽起來很麻煩,我將嘗試用一個簡單的 React 示例來說明這一點。在下面的代碼示例中,我們將在組件內獲取并顯示圖像/ gif。

  首先,讓我們看一下這個簡單應用程序應該是什么樣子的最終結果,我們有兩個組件彼此疊加,頂部名為 RandomGif,底部名為 SearchImg。

41

  最終結果

  這兩個組件都在 App.js內:

42

  隨機極譜和搜索磁共振組件

  組件名稱說明了一切,隨機GIF顯示隨機GIF,搜索Img為用戶提供了使用輸入字段值搜索圖像的可能性。 我們將使用兩個 API 端點(Giphy 和 Pixabay),訪問密鑰將在我們注冊時自動生成。

  現在,從隨機Gif組件開始,*下面的API_KEY存儲在.env文件中。

43

  搜索模塊組件:

44

  正如我們所看到的,RandomGif和ScerImg之間的邏輯基本上是相同的,唯一的區別是我們使用兩個不同的端點,在SearchImg組件中有一個輸入字段和一個onChange事件處理程序,它以輸入值為目標,并使用戶能夠通過值查詢來搜索圖像, 更容易解釋的是,在同一API調用邏輯中有不同的參數。

  創建這樣的組件很簡單,但是如果我們有更多的組件,我們在其中進行相同的API調用但具有不同的參數,我們不想復制相同的代碼并將其粘貼到每個組件中,對吧?

  一個好的解決方案是自定義一個 Hook 來封裝組件之間并共享相同的邏輯,如 React Hooks 簡介所示:

  自定義鉤子是一個 JavaScript 函數,其名稱以“use”開頭,可以調用其他鉤子。 (例如: useFetch )

  讓我們為上面的這個例子創建一個自定義的鉤子,我將它命名為useFetch

45

  在上面的代碼中,我們創建了一個名為包含函數的新文件,其中包含獲取數據所需的所有邏輯。邏輯是從組件中復制的( fetchGif / fetchImg ),我們只是刪除了硬編碼的URL,并將它們替換為可以傳遞給自定義 Hook 的變量。useFetch.jsuseFetchurl

  自定義 Hook 不需要有特定的簽名,我們可以決定它接受什么作為參數,以及它應該返回什么(如果有的話),在這種情況下:(url)和return [{ img }, fetchImg]

  返回值 { img } 是初始化為 null 的 img 狀態,將在組件內導入和使用

  函數 fetchImg 將被導入并在組件內部使用

  而且,正如鉤子介紹中所示,從自定義鉤子調用預定義的 React 庫 Hook 是合法的,因此我們在這里使用了 useState 鉤子,它在兩個組件中完全相同。

  現在我們可以更新這兩個組件并使用此自定義鉤子:

46

  上面的代碼解釋道:

  我們導入我們的定制鉤子

47

  使用從我們的自定義鉤子返回的狀態和獲取函數

48

  請注意,這里的 fetchImg 函數不用于更新“img”狀態,它是來自 useFetch 自定義鉤子的提取函數,可以在另一個函數中調用,在這種情況下,按鈕 onClick 事件為“const SearchImg = () = > fetchImg()”和“const getRandomGif = () = > fetchImg()”。

  到目前為止,應用程序中沒有任何更改,但現在我們可以在任何組件中重用此自定義鉤子,只要它們使用相同的邏輯,就可以從任何URL獲取數據。使用自定義鉤子,我們可以將組件邏輯提取到可重用的函數中。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
開班信息
北京校區
  • 北京校區
  • 大連校區
  • 廣州校區
  • 成都校區
  • 杭州校區
  • 長沙校區
  • 合肥校區
  • 南京校區
  • 上海校區
  • 深圳校區
  • 武漢校區
  • 鄭州校區
  • 西安校區
  • 青島校區
  • 重慶校區
  • 太原校區
  • 沈陽校區
  • 南昌校區
  • 哈爾濱校區
国产精品免费久久| 99色视频在线观看| 日韩综合| 日本免费看视频| 高清一级淫片a级中文字幕| 99色播| 久久国产影视免费精品| 国产a一级| 国产视频一区二区在线播放| 国产国产人免费视频成69堂| 国产激情一区二区三区| 成人免费网站久久久| 国产成人精品综合在线| 欧美大片一区| 成人免费观看男女羞羞视频| 成人免费观看视频| 可以免费看毛片的网站| 高清一级片| 亚洲精品中文字幕久久久久久| 91麻豆国产| 亚洲精品中文一区不卡| 中文字幕一区二区三区精彩视频| 91麻豆爱豆果冻天美星空| 国产精品免费精品自在线观看| 成人影院一区二区三区| 午夜久久网| 亚洲www美色| 日韩中文字幕一区| 成人高清视频在线观看| 日本免费乱理伦片在线观看2018| 国产一区二区精品| 国产一区二区精品| 欧美激情在线精品video| 国产成人女人在线视频观看| 日韩中文字幕一区| 天天做人人爱夜夜爽2020毛片| 香蕉视频久久| 一级女人毛片人一女人| 青青久久国产成人免费网站| 国产一区免费观看| 黄色短视屏| 一级女性大黄生活片免费| 成人免费高清视频| 一级女性全黄久久生活片| 一级毛片看真人在线视频| 国产不卡福利| 久久99中文字幕久久| 精品视频在线观看视频免费视频| 国产一区二区高清视频| 天天做日日爱| 99久久视频| 中文字幕97| 国产不卡高清| 国产一区二区精品| 精品视频在线看 | 999久久66久6只有精品| 黄色福利片| 久久久久久久久综合影视网| 日日夜夜婷婷| 一级片片| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美a级片免费看| 久久国产精品只做精品| 黄视频网站在线看| 国产不卡福利| 高清一级做a爱过程不卡视频| 日韩女人做爰大片| 精品国产香蕉在线播出| 999久久久免费精品国产牛牛| 中文字幕一区二区三区精彩视频| 国产一区二区精品久久| 久久成人综合网| 久久国产精品永久免费网站| 久久国产精品只做精品| a级毛片免费观看网站| 麻豆污视频| 亚洲第一视频在线播放| 美女免费毛片| 日本伦理黄色大片在线观看网站| 可以在线看黄的网站| 欧美a级片免费看| 免费国产一级特黄aa大片在线| 香蕉视频亚洲一级| 久久精品欧美一区二区| 一级毛片看真人在线视频| 国产极品精频在线观看| 日韩欧美一二三区| 欧美大片a一级毛片视频| 99久久精品国产高清一区二区| 欧美a级片免费看| 免费一级片在线| 国产不卡高清| 亚洲爆爽| 色综合久久久久综合体桃花网| 国产美女在线一区二区三区| 国产一级强片在线观看| 成人免费网站视频ww| 日韩在线观看网站| 欧美激情一区二区三区在线播放| 欧美国产日韩精品| 亚欧乱色一区二区三区| 国产网站免费| 国产成人精品综合在线| 久久久成人影院| 日本特黄特黄aaaaa大片 | 韩国三级视频网站| 欧美另类videosbestsex久久| 精品国产香蕉伊思人在线又爽又黄| 91麻豆爱豆果冻天美星空| 日韩在线观看免费| 亚欧成人乱码一区二区 | 亚欧视频在线| 九九九网站| 青青青草影院| 可以免费在线看黄的网站| 免费的黄视频| 韩国毛片| 日本伦理黄色大片在线观看网站| 国产成+人+综合+亚洲不卡 | 毛片高清| 精品国产三级a∨在线观看| 超级乱淫伦动漫| 黄色福利片| 九九热国产视频| 国产精品自拍在线| 香蕉视频久久| 黄视频网站免费观看| 久草免费在线色站| 日本特黄一级| 日韩中文字幕一区| 国产网站免费在线观看| 精品国产一区二区三区久久久蜜臀 | 国产网站在线| 国产一区二区精品| 久久福利影视| 成人免费一级纶理片| 99久久精品费精品国产一区二区| 国产一区免费在线观看| 欧美激情一区二区三区视频高清| 午夜久久网| 韩国毛片| 国产一级强片在线观看| 亚洲 激情| 香蕉视频一级| 久久国产精品只做精品| 免费一级生活片| 欧美另类videosbestsex高清| 午夜在线影院| 国产精品1024在线永久免费| 久久精品成人一区二区三区| 日本免费乱理伦片在线观看2018| 91麻豆爱豆果冻天美星空| 欧美激情伊人| 亚欧乱色一区二区三区| 四虎影视库| 国产麻豆精品免费视频| 国产精品自拍一区| 一a一级片| 四虎影视久久久| 国产麻豆精品免费视频| 日本特黄特色aaa大片免费| 日韩免费片| 欧美电影免费| 免费一级生活片| 欧美激情伊人| 九九精品在线| 国产欧美精品午夜在线播放| 精品久久久久久综合网| 国产成人啪精品视频免费软件| 精品国产一区二区三区久| 国产视频一区二区在线观看| 可以免费看污视频的网站| 日本免费区| 色综合久久天天综合观看| 午夜激情视频在线观看| 精品视频一区二区三区| 99久久精品国产高清一区二区| 国产韩国精品一区二区三区| 免费一级生活片| 成人高清视频在线观看| 精品国产三级a∨在线观看| 欧美a级片视频| 国产一区二区精品久久91| 日日夜夜婷婷| 999精品在线| 国产网站在线| 国产不卡福利| 韩国三级视频网站| 精品国产一区二区三区久久久蜜臀 | 欧美日本免费| 欧美激情在线精品video| 999精品视频在线| 二级片在线观看| 国产国语对白一级毛片| 国产网站在线| 97视频免费在线观看| 你懂的日韩| 国产a视频| 青青久久精品国产免费看| 成人影院一区二区三区|