反应动态表单输入 ref typeError
React dynamic form input ref typeError
我有一个带有动态输入字段的 React 表单,用户可以添加和删除输入字段。我在提交表格时进行验证。如果输入为空,输入将通过 useRef 钩子获得焦点。问题是,如果我有两个输入为空,所以我添加第二个输入并在之后删除它,我得到 typeError“无法读取 null 的属性(读取 'focus')”。我也尝试使用动态 useRef 输入,但我无法修复它。
App.js
import React, { useState, useRef } from "react";
import ReactDOM from "react-dom";
import "./styles.css";
function App() {
const [fields, setFields] = useState([""]);
const fieldRef = useRef();
const fieldsIsValid =
fields.length >= 1 && fields.every((field) => field.trim() !== "");
function handleChange(i, event) {
const values = [...fields];
values[i] = event.target.value;
setFields(values);
}
function handleAdd() {
const values = [...fields];
values.push("");
setFields(values);
}
function handleRemove(i) {
const values = [...fields];
values.splice(i, 1);
setFields(values);
}
function submitHandler(event) {
event.preventDefault();
if (!fieldsIsValid) {
if (fields.length >= 1) {
fieldRef.current.focus();
return;
}
return;
}
console.log(fields);
}
return (
<div className="App">
<h1>Hello CodeSandbox</h1>
<form onSubmit={submitHandler}>
<button type="button" onClick={() => handleAdd()}>
Add Input
</button>
{!fieldsIsValid && <p className="error">Input is required</p>}
{fields.map((field, idx) => {
return (
<div key={`${"input"}-${idx}`}>
<input
type="text"
placeholder="Enter text"
value={field || ""}
ref={fieldRef}
onChange={(e) => handleChange(idx, e)}
/>
<button type="button" onClick={() => handleRemove(idx)}>
X
</button>
</div>
);
})}
<button className="margin-top" type="submit">
Submit
</button>
</form>
</div>
);
}
export default App;
您将需要 inputRef
始终跟踪您要聚焦的对象。例如删除后,将 inputRef 指向最后一个非空输入。
另一种方法(我认为更好)是通过常规的 js 代码。这样你就不需要担心跟踪最后一个,你只需要关注第一个空的输入。
const inputRefs = document.querySelectorAll("#myform input");
for (let i = 0; i < inputRefs.length; i++) {
if (!inputRefs[i].value && inputRefs[i].required) {
inputRefs[i].focus();
break;
}
}
https://codesandbox.io/s/react-dynamic-form-forked-8gnww
编辑:已更新以生成一些必需的输入
我有一个带有动态输入字段的 React 表单,用户可以添加和删除输入字段。我在提交表格时进行验证。如果输入为空,输入将通过 useRef 钩子获得焦点。问题是,如果我有两个输入为空,所以我添加第二个输入并在之后删除它,我得到 typeError“无法读取 null 的属性(读取 'focus')”。我也尝试使用动态 useRef 输入,但我无法修复它。
App.js
import React, { useState, useRef } from "react";
import ReactDOM from "react-dom";
import "./styles.css";
function App() {
const [fields, setFields] = useState([""]);
const fieldRef = useRef();
const fieldsIsValid =
fields.length >= 1 && fields.every((field) => field.trim() !== "");
function handleChange(i, event) {
const values = [...fields];
values[i] = event.target.value;
setFields(values);
}
function handleAdd() {
const values = [...fields];
values.push("");
setFields(values);
}
function handleRemove(i) {
const values = [...fields];
values.splice(i, 1);
setFields(values);
}
function submitHandler(event) {
event.preventDefault();
if (!fieldsIsValid) {
if (fields.length >= 1) {
fieldRef.current.focus();
return;
}
return;
}
console.log(fields);
}
return (
<div className="App">
<h1>Hello CodeSandbox</h1>
<form onSubmit={submitHandler}>
<button type="button" onClick={() => handleAdd()}>
Add Input
</button>
{!fieldsIsValid && <p className="error">Input is required</p>}
{fields.map((field, idx) => {
return (
<div key={`${"input"}-${idx}`}>
<input
type="text"
placeholder="Enter text"
value={field || ""}
ref={fieldRef}
onChange={(e) => handleChange(idx, e)}
/>
<button type="button" onClick={() => handleRemove(idx)}>
X
</button>
</div>
);
})}
<button className="margin-top" type="submit">
Submit
</button>
</form>
</div>
);
}
export default App;
您将需要 inputRef
始终跟踪您要聚焦的对象。例如删除后,将 inputRef 指向最后一个非空输入。
另一种方法(我认为更好)是通过常规的 js 代码。这样你就不需要担心跟踪最后一个,你只需要关注第一个空的输入。
const inputRefs = document.querySelectorAll("#myform input");
for (let i = 0; i < inputRefs.length; i++) {
if (!inputRefs[i].value && inputRefs[i].required) {
inputRefs[i].focus();
break;
}
}
https://codesandbox.io/s/react-dynamic-form-forked-8gnww
编辑:已更新以生成一些必需的输入