亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

怎么把commentLists中的index傳遞到APP.js中

commentsList.js?handleDelete(index){console.log(index)this.props.delete(index);}render?(){const?{comments}?=?this.props;return?(<div?className="comment-list-compenent"><label>評論列表</label><ul?className="list-group?mb-3">{comments.map((comment,?index)?=><likey={index}className="list-group-item"onClick?=?{this.handleDelete}index?=?{index}>{comment}</li>)}</ul></div>)}

DeleteItem(index){

const list = [...this.state.comments];

list.splice(index, 1);

this.setState({

comments: list //如果key和值是一樣的直接寫一個就行了

});

}


正在回答

2 回答

這里有一個很關鍵的地方需要注意。子組件純函數是沒有this 的,所以通過

this.props.XXX

是無法調用的。正確的方法應該是在子組件純函數的頭部引入父組件的:函數名、參數變量,如下:

const?CommentList?=?({comments,onDeleteThis})?=>?{}

這個時候,才能在子組件的純函數內使用:

comments,onDeleteThis


0 回復 有任何疑惑可以回復我~

你這沒有把index傳出去啊,可以用箭頭函數

onClick={()=>{this.props.deleteComment(index)}}

App.js中

<CommentList
????comments={comments}
????deleteComment={this.deleteComment}
/>
deleteComment(index){
??let?newComments=this.state.comments;
??newComments.splice(index,1);
??this.setState({
????comments:newComments
??})
}


0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

怎么把commentLists中的index傳遞到APP.js中

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號