Irf*_*fan 2 javascript arrays string jsx reactjs
所以我正在开发一个测验应用程序,所以这是我第一次启动时应用程序的初始状态,我还有 quizApplication.js 组件存储所有问题和答案,
{
question: "I am task oriented in order to achieve certain goals",
answers: [
{
type: "Brown,D,JP",
content: "Hell Ya!"
},
{
type: " ",
content: "Nah"
}
]
},
Run Code Online (Sandbox Code Playgroud)
这是我设置用户答案的功能
setUserAnswer(answer) {
if (answer.trim()) {
const answer_array = answer.split(',');
const updatedAnswersCount = update(this.state.answersCount, {
[answer]: {$apply: (currentValue) => currentValue + 1},
});
this.setState({
answersCount: updatedAnswersCount,
answer: answer
});
}
}
Run Code Online (Sandbox Code Playgroud)
我也有一个像这样的 AnswerOption 组件
function AnswerOption(props) {
return (
<AnswerOptionLi>
<Input
checked={props.answerType === props.answer}
id={props.answerType}
value={props.answerType}
disabled={props.answer}
onChange={props.onAnswerSelected}
/>
<Label className="radioCustomLabel" htmlFor={props.answerType}>
{props.answerContent}
</Label>
</AnswerOptionLi>
);
}
Run Code Online (Sandbox Code Playgroud)
所以我试图做的是,每当用户点击 HellYa!它会将“Brown”和“D”和“JP”增加+1,但现在它给了我一个新的 answersCount 值作为 Brown,D,JP: null,那么我应该如何实现呢?非常感谢!
你已经拆分了你的type,但还没有使用它们。
当你拆分你的type,你会得到answer_array一个3包含的长度["Brown", "D", "JP"]
const answer_array = answer.split(',');
Run Code Online (Sandbox Code Playgroud)
接下来,您将使用更新的答案计数更新您的状态。您正在执行以下操作
const updatedAnswersCount = update(this.state.answersCount, {
[answer]: {$apply: (currentValue) => currentValue + 1},
});
Run Code Online (Sandbox Code Playgroud)
这里answer包含"Brown,D,JP". 由于您希望通过 +1 更新每个值,因此让我们遍历拆分值并更新它。
let updatedAnswersCount = null;
answer_array.forEach((key) => {
updatedAnswersCount = update(this.state.answersCount, {
[answer]: {$apply: (currentValue) => currentValue + 1},
});
}
Run Code Online (Sandbox Code Playgroud)
在这里,我假设您的类型是独一无二的。含义Brown/ D/JP只是这个答案,不为别的礼物。所以我们假设所有的值都相同。
| 归档时间: |
|
| 查看次数: |
34527 次 |
| 最近记录: |