React 受控组件,Hooks 方式!

开发 前端
React 提供了两种方法来访问input字段的值:使用受控或非受控组件。我更喜欢受控组件,因为我们可以通过组件的状态读取和设置input的值。

[[388260]]

本文已经过原作者 Shadeed 授权翻译。

React 提供了两种方法来访问input字段的值:使用受控或非受控组件。我更喜欢受控组件,因为我们可以通过组件的状态读取和设置input的值。

在这篇文章中,我们来看看如何使用React Hook 实现受控组件。

1.受控组件

假设我们有一个简单的文本字段,并且想访问其值:

  1. import { useState } from 'react'
  2.  
  3. function MyControlledInput({ }) { 
  4.   const [ value, setValue ] = useState(''); 
  5.   const onChange = (event) => { 
  6.     setValue(event.target.value); 
  7.   } 
  8.    
  9.   return ( 
  10.     <> 
  11.         <div>Input value: {value}</div> 
  12.         <input value={value} onChange={onChange} /> 
  13.     </> 
  14.   ) 

打开示例(https://codesandbox.io/s/controlled-component-uwf8n)并在输入框中输入。可以看到 value 变量包含input字段中的值,并且在每次输入新值时,它也会更新。

input字段受到控制,因为 React 从状态设置其值。当用户在input 中输入内容时,onChange处理程序会使用从事件对象event.target.value访问的输入值来更新状态。

value变量表示用户真实输入的值。每次需要访问用户在input字段中输入的值时,只需读取value状态变量。

受控组件方法可以帮助我们访问任何输入类型的值:常规文本输入、textarea、select 等。

2. 受控组件中的3个步骤中

设置受控组件需要3个步骤:

定义保存input值的状态:const [value, setValue] = useState(")。

创建事件处理程序,该事件处理程序在值更改时更新状态:

  1. const onChange = event => setValue(event.target.value); 

3.为input字段分配状态值,并添加事件处理程序:

3. state 作为真实的数组源

我们看一个更复杂的例子。页面中有一组员工姓名列表。我们需要添加一个 input字段,当用户在此字段中键入内容时,员工列表将按姓名进行过滤。

  1. function FilteredEmployeesList({ employees }) { 
  2.  const [query, setQuery] = useState('');   
  3.  const onChange = event => setQuery(event.target.value); 
  4.   const filteredEmployees = employees.filter(name => { 
  5.     return name.toLowerCase().includes(query.toLowerCase()); 
  6.   }); 
  7.  
  8.   return ( 
  9.     <div> 
  10.  <h2>Employees List</h2> 
  11.  <input  
  12.         type="text"  
  13.  value={query}        onChange={onChange}      /> 
  14.  <div className="list"
  15.  {filteredEmployees.map(name => <div>{name}</div>)} 
  16.  </div> 
  17.  </div> 
  18.   ); 

打开演示(https://codesandbox.io/s/gracious-dawn-29qi6?file=/src/App.js),可以自行试试。

对输入进行防抖

在前面的实现中,只要在input中输入一个字符,就会立即过滤列表。这并不总是很方便,因为在输入查询时它会分散用户的注意力。

我们通过debounce来改善用户体验:在最后一次更改后,以400毫秒的延迟过滤列表。

  1. import { useDebouncedValue } from './useDebouncedValue'
  2. function FilteredEmployeesList({ employees }) { 
  3.   const [query, setQuery] = useState(''); 
  4.  const debouncedQuery = useDebouncedValue(query, 400);   
  5.   const onChange = event => setQuery(event.target.value); 
  6.  
  7.   const filteredEmployees = employees.filter(name => { 
  8.  return name.toLowerCase().includes(debouncedQuery.toLowerCase());  }); 
  9.  
  10.   return ( 
  11.     <div> 
  12.  <h2>Employees List</h2> 
  13.  <input  
  14.         type="text"  
  15.         value={query}  
  16.         onChange={onChange} 
  17.       /> 
  18.  <div className="list"
  19.  {filteredEmployees.map(name => <div>{name}</div>)} 
  20.  </div> 
  21.  </div> 
  22.   ); 

打开演示(https://codesandbox.io/s/affectionate-swartz-9yk2u?file=/src/App.js),然后在input中输放值进行查询。员工列表不会在你打字时进行过滤,而是在最近一次按下键400毫秒后进行过滤。

下面是useDebouncedValue()的实现

  1. export function useDebouncedValue(value, wait) { 
  2.   const [debouncedValue, setDebouncedValue] = useState(value); 
  3.  
  4.   useEffect(() => { 
  5.     const id = setTimeout(() => setDebouncedValue(value), wait); 
  6.     return () => clearTimeout(id); 
  7.   }, [value]); 
  8.  
  9.   return debouncedValue; 

受控组件是访问React中input字段的值的一种方便的技术。它不使用引用,而是作为访问input值的单一真实源。

~ 完,我们小智,我要去刷碗了,下期再见~

作者:Shadeed 译者:前端小智 来源:dmitripavlutin

原文:https://dmitripavlutin.com/controlled-inputs-using-react-hooks/

本文转载自微信公众号「大迁世界」,可以通过以下二维码关注。转载本文请联系大迁世界公众号。

 

责任编辑:武晓燕 来源: 大迁世界
相关推荐

2022-07-06 08:29:12

antdInput 组件

2020-10-21 08:38:47

React源码

2021-07-09 08:33:35

React组件受控

2019-03-13 10:10:26

React组件前端

2022-07-18 09:01:58

React函数组件Hooks

2019-08-20 15:16:26

Reacthooks前端

2023-11-06 08:00:00

ReactJavaScript开发

2022-03-31 17:54:29

ReactHooks前端

2022-08-09 13:22:26

Hooksreactvue

2022-08-21 09:41:42

ReactVue3前端

2020-10-28 09:12:48

React架构Hooks

2020-09-19 17:46:20

React Hooks开发函数

2020-03-16 10:25:49

前端React Hooks响应式布局

2022-03-16 09:17:41

函数useStaterender

2022-04-16 20:10:00

React Hookfiber框架

2022-03-22 09:09:17

HookReact前端

2023-05-11 08:57:49

ReactHooks

2022-02-10 19:15:18

React监听系统模式

2021-05-11 08:48:23

React Hooks前端

2024-02-05 21:48:25

VueReactHooks
点赞
收藏

51CTO技术栈公众号