[英]array.splice() deleting wrong element
我是一個反應 js 的初學者,想知道為什么 splice() 方法對我來說不能正常工作。 我的方法在這里:
removePara = index => {
let array = [...this.state.paras];
for (let x = 0; x < this.state.count; x++) {
try {
if (array[x].props.id == index) {
array.splice(x, 1);
}
} catch (e) {}
}
this.setState({ paras: array });
};
所以我傳遞了一個索引,如果元素的 id 與索引匹配,則刪除該元素。 我使用了 try-catch ,因為並非所有索引都在那里(它們可能已通過相同的函數被刪除)。 這是三個元素的圖像:
不是第二個被刪除,而是最后一個被刪除。 我該如何解決? 我知道我的按鈕的 onclick 工作正常。 完整代碼如下:
//index.js
const rootElement = document.getElementById("root");
class App extends React.Component {
state = {
paras: [],
count: 0
};
addPara = () => {
this.setState({
paras: [
...this.state.paras,
<Paragraph id={this.state.count++} remove={this.removePara} />
]
});
};
removePara = index => {
let array = this.state.paras.filter(e => e.props.id !== index);
this.setState({ paras: array });
};
render() {
return (
<div>
{this.state.paras}
<div className="btn btn-warning" id="add" onClick={this.addPara}>
Add Paragraph
</div>
<div name="count">{this.state.count}</div>
</div>
);
}
}
ReactDOM.render(<App />, rootElement);
//Paragraph.js
class Paragraph extends React.Component {
render() {
let style = {
height: "150px",
marginBottom: "10px"
};
return (
<div className="paragraph" id={this.props.id}>
<div className="row">
<div className="col-sm-11">
<textarea
className="form-control"
name={"paragraph" + this.props.id}
placeholder="Put Paragraph Here"
style={style}
required
></textarea>
</div>
<div className="col-sm-1">
<div
className="btn btn-danger del-rotate"
onClick={() => this.props.remove(this.props.id)}
>
×
</div>
</div>
</div>
</div>
);
}
}
<!--index.html-->
<html>
<head>
<script type="application/javascript" src="../reactjs/react.js"></script>
<script type="application/javascript" src="../reactjs/react-dom.js"></script>
<script type="application/javascript" src="../reactjs/babel.js"></script>
<link rel="stylesheet" type="text/css" href="../css/styles.css">
<script src="../bootstrap/js/bootstrap.min.js"></script>
<link rel="stylesheet" type="text/css" href="../bootstrap/css/bootstrap.min.css">
<script type="text/babel" src="Components/Paragraph.js"></script>
<script type="text/babel" src="index.js"></script>
</head>
<body id="body">
<div class="container-fluid">
<br>
<br>
<div class="row">
<div class="col-sm-1"></div>
<div class="col-sm-10">
<div align="center">
<h1>Write Article</h1>
</div>
<br>
<form action="submit-article.php" method="POST">
<input class="form-control input-sm" type="text" placeholder="Enter Title" name="title"
style="width: 35%" autofocus required></input>
<br>
<div id="root"></div>
<br>
<input class="btn btn-success float-right" type="submit" value="Done">
</form>
</div>
</div>
</div>
</body>
</html>
但是與 id 匹配的元素被刪除,就像在元素中一樣,它不存在,但是被刪除的元素的輸入只會進入另一個元素。 就像上面圖片中的例子一樣
可能您傳遞的index
不正確,
Array.filter
更適合這種任務:
removePara = index => {
let array = this.state.paras.filter(e => e.props.id !== index);
this.setState({ paras: array });
};
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.