波多野结衣 蜜桃视频,国产在线精品露脸ponn,a v麻豆成人,AV在线免费小电影

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:52010
  • 待審:67
  • 小程序:12
  • 文章:1106242
  • 會員:784

react 是一個用于構建用戶界面的流行 javascript 庫。它以高效且專注于創建可重用的 ui 組件而聞名。 react 的關鍵特性之一是引入了鉤子,它是掛鉤到 react 狀態的函數。這些鉤子中的一個是 usetransition 鉤子。該鉤子允許在不阻塞界面的情況下進行狀態更改,從而帶來流暢的體驗。

了解 usetransition 鉤子

為了更好地理解 usetransition 鉤子,我們將研究以下示例。

import {usestate} from "react"

const app = () => {
  const [post, setpost] = usestate(undefined)

  const fetchdata = async () => {
    await fetch("https://jsonplaceholder.org/posts/1")
      .then((result) => result.json())
      .then((result) => setpost(result))
  }

  return(
    <div>
      {post !== undefined &amp;&amp; (
      <div classname="post-card">
        <h2>{post?.title}</h2>
        <image src="%7Bpost?.image%7D"></image><p>{post?.content}</p>
      </div>
      )}
      <button onclick="{fetchdata}">
        get post
      </button>
    </div>
  )
}

export default app; 

登錄后復制

當用戶單擊按鈕時,根據互聯網的速度或 fetchdata 函數內執行的任務的繁重,ui 可能會在獲取任務期間凍結,這將導致用戶體驗不佳。如果您不希望用戶濫用您的應用程序,也可能會向按鈕發送垃圾郵件。此外,應用程序不會向用戶顯示任何正在進行的操作的指示。

使用 usetransition 鉤子可以輕松解決這些問題,我們可以將之前的代碼更新為類似這樣的內容。

import {useState, useTransition} from "react"
import {ImSpinner2} from "react-icons/im"

const App = () =&gt; {
  const [pending, startTransition] = useTransition()
  const [post, setPost] = useState({})

  const fetchData = () =&gt; {
    startTransition( async () =&gt; {
      await fetch("https://jsonplaceholder.org/posts/1")
        .then((result) =&gt; result.json())
        .then((result) =&gt; setPost(result))
    })
  }

  return(
    <div>
      {post !== undefined &amp;&amp; (
      <div classname="post-card">
        <h2>{post.title}</h2>
        <image src="%7Bpost.image%7D"></image><p>{post.content}</p>
      </div>
      )}
      <button disabled onclick="{fetchData}">
        {pending ? <imspinner2 classname="animate-spin"></imspinner2> : "Get post" }
      </button>
    </div>
  )
}

export default App; 

登錄后復制

調用的usetransition鉤子返回兩個值:pending,如果任務執行完畢并且starttransition函數包含可能被更緊急的任務打斷的任務,則該值將為true。

在上面的示例中,我們將獲取請求包裝在 starttransition 函數內的異步箭頭函數中。

并且在按鈕中,我們以包含鏈接到待處理的禁用屬性的方式對其進行修改,并且我們更改了按鈕的標簽,以在任務待處理時顯示微調器,并在任務待處理時顯示標簽“獲取帖子”任務沒有待處理。

這會帶來流暢的用戶體驗,并提供更好的性能,并保護您的應用程序免受用戶不當行為的影響。

結論

usetransition 鉤子是一個游戲規則改變者,用于構建具有流暢用戶體驗的高性能 react 應用程序。它確保 ui 在可能緩慢的操作期間保持響應并防止 ui 凍結,從而增強整體用戶體驗。

分享到:
標簽:hook useTransition 如何使用 性能 提高
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 52010

    網站

  • 12

    小程序

  • 1106242

    文章

  • 784

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定