gpt4 book ai didi

javascript - react : How can I control a list of <input> with state?

转载 作者:行者123 更新时间:2023-11-29 17:35:12 24 4
gpt4 key购买 nike

这是一个组件的最小工作示例,其中包含一种从列表创建的输入形式,以及一种从单个值创建的输入形式:

import React from 'react';

export default class App extends React.Component {
constructor(props) {
super(props);
}

state = {
value: 'single value',
values: ['one', 'two'],
}

render() {
let test = this.state.values.map( (v, i) => {
return <input
key={ v }
value={ v }
onChange={ (e) => {
let values = this.state.values;
values[i] = e.target.value;
this.setState({ values });
} }
/>;
} )

return <div>
<form>
{ test }
</form>
<form>
<input
value={ this.state.value }
onChange={ (e) => this.setState({ value: e.target.value }) }
/>
</form>
</div>;
}
}

产生这个:

enter image description here

当用户编辑第三个输入字段(“单值”)时,一切正常。用户输入内容,状态更新,大家都很高兴。

然而,当用户编辑前两个输入字段中的任何一个时,光标会在状态更新后立即失去焦点。要编辑此字段,用户必须在输入任何字母后单击该字段。

我该如何解决这个问题?有没有办法防止组件模糊 <input> ,或者有更好的方法来解决这个问题吗?

我不知道如何录制我的屏幕并从中制作 GIF。如果您不明白我的意思,我建议您使用 npx create-react-app my-app 创建一个 React 应用程序并编辑 my-app/src/App.js到我的代码示例。

最佳答案

问题是您将值作为 key 传递,对于每个新值,您都会得到一个新的 key,它 react “认为”它是一个新元素,因此重新-mount 元素,你失去了焦点

Read more about keys

let test = this.state.values.map( (v, i) => {
return <input
key={ v }
value={ v }
onChange={ (e) => {
let values = this.state.values;
values[i] = e.target.value;
this.setState({ values });
} }
/>;
} )

不确定是否可以更改 state 结构,但我会采用不同的方法并创建一个 form 对象并提供 namekey 属性根据对象的键。

例子:

class App extends React.Component {
state = {
form: {
name: "",
userName: "",
age: ""
},
externalValue: ""
};

onFormInputChange = ({ target }) => {
const { form } = this.state;
this.setState({
form: {
...form,
[target.name]: target.value
}
});
};

onInputChange = ({ target }) => {
this.setState({ [target.name]: target.value });
};

render() {
const { form } = this.state;
let test = Object.entries(form).map(([key, value]) => {
return (
<input
key={key}
name={key}
placeholder={key}
value={value}
onChange={this.onFormInputChange}
/>
);
});

return (
<div>
<form>{test}</form>
<form>
<input
name="externalValue"
placeholder="externalValue"
value={this.state.value}
onChange={this.onInputChange}
/>
</form>
</div>
);
}
}
const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
<div id="root"/>

关于javascript - react : How can I control a list of &lt;input&gt; with state?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57145861/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com