久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

        手機站
        千鋒教育

        千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

        千鋒教育

        掃一掃進入千鋒手機站

        領(lǐng)取全套視頻
        千鋒教育

        關(guān)注千鋒學(xué)習(xí)站小程序
        隨時隨地免費學(xué)習(xí)課程

        當前位置:首頁  >  技術(shù)干貨  > 反應(yīng):創(chuàng)建使用取型自定義鉤子

        反應(yīng):創(chuàng)建使用取型自定義鉤子

        來源:千鋒教育
        發(fā)布人:syq
        時間: 2022-09-14 18:13:33 1663150413

          有關(guān)在 React 中創(chuàng)建自定義鉤子以跨所有組件使用 Fetch 的教程。

          從版本 16.8 開始,React 鉤子被正式添加到 React.js。除了內(nèi)置的 Hooks 之外,我們還可以定義自己的 hook 來使用狀態(tài)和其他 React 特性,而無需編寫類。

        創(chuàng)建使用取型自定義鉤子

          當您的組件邏輯需要由多個組件使用時,我們可以將該邏輯提取到自定義掛鉤中。例如,如果您需要從不同組件中的服務(wù)器獲取數(shù)據(jù),則必須在每個組件中編寫 fetch 函數(shù),然后添加用于處理加載和錯誤狀態(tài)的狀態(tài)。我們不必在每個組件中放置 fetch,而是可以創(chuàng)建自定義鉤子并在任何地方重用它。

          自定義鉤子以“use”前綴開頭。例如。useFetch

          步驟1

          讓我們創(chuàng)建一個新文件:useFetch.js

        4

          在導(dǎo)入我們的鉤子并像任何其他鉤子一樣使用它。這是我們傳入URL以從中獲取數(shù)據(jù)的地方?,F(xiàn)在我們可以在任何組件中重用這個自定義 Hook,從任何 URL 獲取數(shù)據(jù)。app.jsuseFetch

        5

          步驟2:添加加載/錯誤狀態(tài)

          我們還可以添加附加參數(shù)和參數(shù)來指示數(shù)據(jù)是否正在獲取以及是否發(fā)生錯誤。loading error

        6

          用法:

        7

          步驟3:抓取“有什么”問題“?

          讓我們再看一遍這個代碼塊:

        8

          一切似乎都很好,什么可能出錯?您幾乎可以在所有文章和視頻教程中找到此代碼塊。但我想在這里強調(diào)2點。如果:

          首先:服務(wù)器返回無效的 JSON 字符串

          接口 的方法 獲取 流并讀取它直到完成。它返回一個承諾,該承諾通過解析正文文本作為 的結(jié)果進行解析。json() Response Response JSON

          在第(1)行上,我們使用json()函數(shù)解析響應(yīng),但是如果服務(wù)器返回字符串而不是JSON字符串,則此塊將引發(fā)錯誤。假設(shè)我們的服務(wù)器在響應(yīng)中只返回“OK”文本。

          res.status(200).send('OK')

          在這種情況下,我們將獲得成功狀態(tài),但我們的抓取將引發(fā)錯誤:

        9

          無效的 JSON 字符串

          第二:捕獲服務(wù)器錯誤

          如果服務(wù)器返回4xx或5xx狀態(tài)(例如404,500),我們?nèi)詫⑥D(zhuǎn)到阻止而不是阻止。因為這就是提取請求的工作方式。thencatch

          僅當發(fā)生網(wǎng)絡(luò)錯誤時,獲取承諾才會使用類型錯誤拒絕。由于 4xx 和 5xx 響應(yīng)不是網(wǎng)絡(luò)錯誤,因此沒有什么可捕獲的。

          解決這些錯誤

          對于第一點,我們可以添加一個 try/catch 塊(用于和用于處理 Promise 中的錯誤的塊),如果發(fā)生錯誤,我們可以從響應(yīng)中返回文本值。async/awaitcatch

        10

          注意:我們在這里使用是因為我們可以使用或只能使用一次。否則,它將引發(fā)錯誤:clone json text

        11

          對于第二點(處理服務(wù)器錯誤),我們需要檢查響應(yīng)狀態(tài)(可以是或)。res.oktrue false

          法典

        12

          最后的步驟

          將我們的承諾鏈替換為異步/等待

          添加類型腳本

          添加重新獲取選項

          有條件地獲取(不僅在組件裝載上)

          再次調(diào)用自定義掛鉤的唯一方法是在掛鉤中添加依賴項,并將其從組件中更改。useEffect

        13

          例:假設(shè)每次單擊按鈕時都需要獲取數(shù)據(jù)。在按鈕單擊時,我們可以更改切換值,該值在useFetch鉤子中用作依賴項,數(shù)據(jù)將再次被提取。

        14

          現(xiàn)在一切似乎都很好,但是如果我們需要通過單擊按鈕而不是在組件安裝時加載數(shù)據(jù)來加載數(shù)據(jù),該怎么辦?如果我們嘗試添加如下條件,它將引發(fā)錯誤。這是因為鉤子不能在條件下使用。此代碼錯誤 ↓

        15

          我們將收到此錯誤:

          Rendered more hooks than during the previous render.

          為了解決這個問題,我們可以將條件放在自定義鉤子中,而不是將其放在組件中。如果 提供了,值為 — 無需加載數(shù)據(jù)。refetchnull

        17

          例子

          服務(wù)器返回一個字符串而不是 JSON。堆棧閃電戰(zhàn)演示

        18

          通過單擊按鈕重新獲取數(shù)據(jù)。堆棧閃電戰(zhàn)演示

        19

          在按鈕單擊而不是組件安裝時發(fā)出獲取請求。在這里,我們需要設(shè)置這將阻止在組件安裝時發(fā)送請求。param null

        20

          發(fā)出發(fā)布/放置請求

        21

          就是這樣。此外,我們還可以從自定義鉤子添加返回狀態(tài)代碼和錯誤消息。

          您可以在此處找到源代碼,并在此處找到堆棧閃電戰(zhàn)示例。

        tags:
        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
        請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
        免費領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學(xué) 138****2860 剛剛成功領(lǐng)取
        王同學(xué) 131****2015 剛剛成功領(lǐng)取
        張同學(xué) 133****4652 剛剛成功領(lǐng)取
        李同學(xué) 135****8607 剛剛成功領(lǐng)取
        楊同學(xué) 132****5667 剛剛成功領(lǐng)取
        岳同學(xué) 134****6652 剛剛成功領(lǐng)取
        梁同學(xué) 157****2950 剛剛成功領(lǐng)取
        劉同學(xué) 189****1015 剛剛成功領(lǐng)取
        張同學(xué) 155****4678 剛剛成功領(lǐng)取
        鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
        董同學(xué) 138****2867 剛剛成功領(lǐng)取
        周同學(xué) 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        抖店入駐收費多少?開抖店費用是多少?

        如果要開通抖音小店,需要先把抖音賬號開通商品櫥窗功能。入駐之后,可以選擇頭條賬號、抖音賬號、火山賬號任一類型注冊或登錄。那開個抖店要多...詳情>>

        2023-09-19 07:50:26
        想做直播帶貨的貨源哪里來?怎么找貨源?

        現(xiàn)如今直播推廣的方式是非?;鸬?,有著非常多的賣家都是利用直播推廣店鋪產(chǎn)品,效果也是非常不錯。但很多賣家想要了解現(xiàn)在直播帶貨的話什么產(chǎn)品...詳情>>

        2023-09-19 07:47:16
        適合三農(nóng)領(lǐng)域的名字?有何技巧?

        現(xiàn)在在抖音上很多博主會選擇直播來賺取更多的流量以及利潤,直播間的東西也有很多讓消費者信任并且喜歡的,而且隨著越來越多人直播,很多農(nóng)產(chǎn)品...詳情>>

        2023-09-19 07:06:05
        抖店商品發(fā)布違規(guī)怎么申訴?有何規(guī)則?

        抖店服務(wù)市場服務(wù)商發(fā)布違禁信息如何處理?情節(jié)嚴重程度判定原則:違規(guī)嚴重等級主要通過服務(wù)商違規(guī)次數(shù)、造成后果的嚴重程度、獲利或?qū)е聯(lián)p失的...詳情>>

        2023-09-19 06:59:55
        “泛垂直起號”可能是2023年最高效的起號方式

        這可能是明年最好用的旗號方式了,今天教大家一個很野,但是可以讓你三天漲1000粉的偏方。去年前年啊,每個人都教你,誰知七號對著自己的產(chǎn)品拍...詳情>>

        2023-09-19 06:37:38
        開班信息
        北京校區(qū)
        • 北京校區(qū)
        • 大連校區(qū)
        • 廣州校區(qū)
        • 成都校區(qū)
        • 杭州校區(qū)
        • 長沙校區(qū)
        • 合肥校區(qū)
        • 南京校區(qū)
        • 上海校區(qū)
        • 深圳校區(qū)
        • 武漢校區(qū)
        • 鄭州校區(qū)
        • 西安校區(qū)
        • 青島校區(qū)
        • 重慶校區(qū)
        • 太原校區(qū)
        • 沈陽校區(qū)
        • 南昌校區(qū)
        • 哈爾濱校區(qū)
        民县| 安泽县| 宁德市| 高台县| 琼结县| 关岭| 友谊县| 玉树县| 休宁县| 仁化县| 山阴县| 东宁县| 当阳市| 新余市| 富锦市| 色达县| 双柏县| 寻乌县| 利津县| 米林县| 望江县| 武夷山市| 措美县| 雷山县| 德昌县| 马山县| 鹤岗市| 方正县| 呼图壁县| 栾城县| 巴东县| 荥阳市| 南部县| 怀远县| 陈巴尔虎旗| 合水县| 吉安市| 萝北县| 武强县| 鄄城县| 上虞市|