React 自動(dòng)聚焦字段使用詳解
正文
自動(dòng)對(duì)焦可以讓你的應(yīng)用程序更方便用戶使用,有幾種方法可以自動(dòng)聚焦 React 輸入框。
要讓輸入框自動(dòng)聚焦,最簡(jiǎn)單的方法是使用 autoFocus
屬性(注意大小寫):
<input name="username" type="text" autoFocus />
由于該屬性在各個(gè)瀏覽器的工作方式不一致,React 內(nèi)部實(shí)現(xiàn)了一個(gè) polyfill,會(huì)在元素掛載時(shí)使用 focus()
方法。
但這并總是有用,我們需要自己封裝一個(gè)。
有兩種實(shí)現(xiàn)方法:
- 使用
useCallback()
- 使用
useRef()
和useEffect()
我們會(huì)將它編寫成一個(gè) Hooks,以便我們可以在項(xiàng)目中重復(fù)使用它。
使用 useCallback()
useCallback()
鉤子返回一個(gè)已記憶的回調(diào)函數(shù)。它接受兩個(gè)參數(shù)。第一個(gè)是要運(yùn)行的函數(shù),第二個(gè)是運(yùn)行函數(shù)所依賴的值數(shù)組。
import { useCallback } from 'react' const useAutoFocus = () => { const inputRef = useCallback((inputElement) => { if (inputElement) { inputElement.focus() } }, []) return inputRef } export default useAutoFocus
注意到 useCallback
的第二個(gè)參數(shù)是一個(gè)空數(shù)組,這意味著該函數(shù)在組件渲染時(shí)只運(yùn)行一次。
當(dāng)表單組件渲染時(shí),將設(shè)置輸入框的引用。它執(zhí)行 useCallback()
鉤子中的函數(shù),該函數(shù)對(duì)輸入框調(diào)用 focus()
。
使用 useRef() 和 useEffect()
useffect()
鉤子會(huì)告訴 React,在組件渲染之后,您需要組件執(zhí)行一些操作。它接受兩個(gè)參數(shù)。第一個(gè)是要運(yùn)行的函數(shù),第二個(gè)是一個(gè)依賴項(xiàng)數(shù)組,其功能與 useCallback()
中的相同。
useRef()
鉤子對(duì)函數(shù)組件的作用與 createRef()
對(duì)基于類組件的作用相同。這個(gè)鉤子創(chuàng)建了一個(gè)普通的 JavaScript 對(duì)象,您可以將其傳遞給一個(gè)元素,以保持對(duì)它的引用。可以通過(guò)對(duì)象的 current
屬性訪問(wèn)此引用。
import { useRef, useEffect } from 'react' const useAutoFocus = () => { const inputRef = useRef(null) useEffect(() => { if (inputRef.current) { inputRef.current.focus() } }, []) return inputRef } export default useAutoFocus
在上面的代碼中,我們創(chuàng)建了對(duì)輸入框的引用。然后,當(dāng)組件渲染時(shí),我們使用引用對(duì)象的 current
屬性調(diào)用輸入框的 focus()
。
使用示例
import { useState, useEffect } from 'react' import ReactDOM from 'react-dom' import useAutoFocus from './hooks/useAutoFocus' function App() { const emailInput = useAutoFocus() return ( <> <form> <label> 用戶 <input name='username' type='text' ref={emailInput} /> </label> <label> 密碼 <input name='password' type='password' /> </label> <button type='submit'>登錄</button> </form> </> ) } ReactDOM.render(<App />, document.getElementById('root'))
更多資料
以上就是React 自動(dòng)聚焦字段使用詳解的詳細(xì)內(nèi)容,更多關(guān)于React 自動(dòng)聚焦字段的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
從零開(kāi)始搭建一個(gè)react項(xiàng)目開(kāi)發(fā)
這篇文章主要介紹了從零開(kāi)始搭建一個(gè)react項(xiàng)目開(kāi)發(fā),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02使用react-color實(shí)現(xiàn)前端取色器的方法
本文通過(guò)代碼給大家介紹了使用react-color實(shí)現(xiàn)前端取色器的方法,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2021-11-11ahooks正式發(fā)布React?Hooks工具庫(kù)
這篇文章主要為大家介紹了ahooks正式發(fā)布值得擁有的React?Hooks工具庫(kù)使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07React Native 中實(shí)現(xiàn)確認(rèn)碼組件示例詳解
這篇文章主要為大家介紹了React Native中實(shí)現(xiàn)確認(rèn)碼組件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08react-native?父函數(shù)組件調(diào)用類子組件的方法(實(shí)例詳解)
這篇文章主要介紹了react-native?父函數(shù)組件調(diào)用類子組件的方法,通過(guò)詳細(xì)步驟介紹了React 函數(shù)式組件之父組件調(diào)用子組件的方法,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09詳解React Native 采用Fetch方式發(fā)送跨域POST請(qǐng)求
這篇文章主要介紹了詳解React Native 采用Fetch方式發(fā)送跨域POST請(qǐng)求,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11