[英]React-native array check if value exist
如何检查ticketId
已插入数组?
这是代码:
state = { myState: [], status: 0, limit: 5 };
selected(ticketId) {
if (this.state.status < this.state.limit) {
this.state.myState.push({ id: ticketId }); //what ever i chose get inserted
this.state.status++;
this.setState({ status: this.state.status });
//console.log('here', this.state.status);
} else {
console.log('3'); //check if condition meet
}
}
如果ticketId
已插入并触发警报,如何创建条件检查myState
数组?
您好,您可以使用loadash 在这里查找此类问题,它看起来非常好看! :)
范例:1
_.indexOf([1, 2, 1, 2], 2);
// => 1
或者您可以使用
示例:2
var users = [
{ 'user': 'barney', 'active': false },
{ 'user': 'fred', 'active': false },
{ 'user': 'pebbles', 'active': true }
];
_.findIndex(users, function(o) { return o.user == 'barney'; });
// => 0
// The `_.matches` iteratee shorthand.
_.findIndex(users, { 'user': 'fred', 'active': false });
// => 1
// The `_.matchesProperty` iteratee shorthand.
_.findIndex(users, ['active', false]);
// => 0
// The `_.property` iteratee shorthand.
_.findIndex(users, 'active');
// => 2
在你的代码中
_.findIndex(this.state.myState, { 'id': ticketId });
// It will return 0 if there is nothing
// else will return no of index
// where it ticketid is present
// you can do alert on if its not 0
当您存储为对象{id:value}时,最好改用“每一个”。
state = { myState: [], status: 0, limit: 5 };
selected(ticketId) {
if (this.state.status < this.state.limit ) {
if(this.state.myState.every((item) => item.id !== ticketId)){
this.state.myState.push({ id: ticketId }); //what ever i chose get inserted
this.state.status++;
this.setState({ status: this.state.status });
//console.log('here', this.state.status);
}
} else {
console.log('3'); //check if condition meet
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.