我需要按薪水排序后的更新状态
state = {
workers: [
{name: 'Bob', surname: 'Meljanski', salary: 5140},
{name: 'Michel', surname: 'Hensson', salary: 5420},
{name: 'Jane', surname: 'Mitchel', salary: 2054}
}
startSort = () => {
const arr = this.state.workers.slice();
arr[2].name = 'Mike';
var kk = [...arr].sort((a,b) => (a.salary>b.salary)*2-1);
this.setState(kk);
console.log(kk);
}
根据结果。状态呈现而不进行排序。我该怎么做?对不起,我的英语
答案 0 :(得分:7)
setState
接受一个对象(新的状态对象)或一个函数(一个更新程序,该更新程序将在react实际更新状态时运行,通常在下一个状态取决于上一个状态时使用,例如切换等) ,您将数组传递给它。
您可以尝试以下方法:
this.setState({workers: kk});