admin管理员组文章数量:1355731
Hi I am usin Angular and I am struggling for an issue. I would like to know How to use "indexOf()" method on a array which has two or more fields. Here is my code:
My array:
[
{
"id":1,
"name": "stuff",
"surname": "stuff"
},
{
"id":2,
"name": "stuff",
"surname": "stuff"
},
{
"id":3,
"name": "stuff",
"surname": "stuff"
}
]
in my angular Code I would like to a user type a certain id from the template(in the form) and check if the corresponding user exists in my array. my angular code is:
<form #formValue="ngForm" (ngSubmit)="onClick(formValue)">
<div class="form-group">
<label for="exampleInputEmail1">Identifiant du challenge</label>
<input type="text" name="_id" #_id="ngModel" [(ngModel)]="this.user._id"
class="form-control" pattern="[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$"
placeholder="identifiant">
</div>
<input type="submit" value="Submit" class="btn btn-primary"/>
</form>
in my *.ts file I have a method that I perform on the submit event named "onClick" look at my ts file:
onClick(form: NgForm){
this.getUsers(form.value._id)
}
// get users method
getUsers(id: String){
return this._http.get<any[]>(this.url + 'getAllChallenge').subscribe(
(users)=>{
this.users=users;
this.checkExist= this.users.indexOf(id)
if(this.checkExist==-1){
alert("this id you typed doesn't exist in our array")
}
else{
/* here is my issue. this alert if is always printed enven
If I type 1,2 or 3(an
existing id)*/
alert("this Id exist")
}
}
);
}
Thank you in advance!
Hi I am usin Angular and I am struggling for an issue. I would like to know How to use "indexOf()" method on a array which has two or more fields. Here is my code:
My array:
[
{
"id":1,
"name": "stuff",
"surname": "stuff"
},
{
"id":2,
"name": "stuff",
"surname": "stuff"
},
{
"id":3,
"name": "stuff",
"surname": "stuff"
}
]
in my angular Code I would like to a user type a certain id from the template(in the form) and check if the corresponding user exists in my array. my angular code is:
<form #formValue="ngForm" (ngSubmit)="onClick(formValue)">
<div class="form-group">
<label for="exampleInputEmail1">Identifiant du challenge</label>
<input type="text" name="_id" #_id="ngModel" [(ngModel)]="this.user._id"
class="form-control" pattern="[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$"
placeholder="identifiant">
</div>
<input type="submit" value="Submit" class="btn btn-primary"/>
</form>
in my *.ts file I have a method that I perform on the submit event named "onClick" look at my ts file:
onClick(form: NgForm){
this.getUsers(form.value._id)
}
// get users method
getUsers(id: String){
return this._http.get<any[]>(this.url + 'getAllChallenge').subscribe(
(users)=>{
this.users=users;
this.checkExist= this.users.indexOf(id)
if(this.checkExist==-1){
alert("this id you typed doesn't exist in our array")
}
else{
/* here is my issue. this alert if is always printed enven
If I type 1,2 or 3(an
existing id)*/
alert("this Id exist")
}
}
);
}
Thank you in advance!
Share Improve this question edited Sep 10, 2021 at 18:28 darklightcode 2,7721 gold badge16 silver badges18 bronze badges asked Sep 10, 2021 at 18:15 cherif barrycherif barry 531 silver badge6 bronze badges 04 Answers
Reset to default 4Basically, you don't.
The function you want to use is find()
.
You give it a function which should return true or false based on whatever you want. It will then return the first element that matches, or undefined
if no elements do. So, if you get a match, it exists, otherwise, it doesn't. You don't have to explicitly cast to a Boolean, but you can.
this.checkExist = Boolean(this.users.find(user => user.id === id));
This is also a findIndex()
method which returns the index instead of the object itself if you'd prefer that, but if you're using it as a Boolean, using find()
will be safer (since you won't have to check for !== -1
).
If you passed the object to getUsers() function, you could actually do that. I don't know if it is possible in Angular.
a={}
b={}
c=[a,b]
c.indexOf(b) // = 1
Otherwise use the find() method as suggested by others.
You should use findIndex()
var arr = [
{
"id":1,
"name": "stuff",
"surname": "stuff"
},
{
"id":2,
"name": "stuff",
"surname": "stuff"
},
{
"id":3,
"name": "stuff",
"surname": "stuff"
}
]
let index = arr.findIndex((obj) => {
return obj.id == 2
})
console.log(index)
indexOf
find index of a element in array. For ex.:
[1,2,3].indexOf(1); // 0
But if you want to search for element with a property (and find index in array) you can use findIndex
:
this.users.findIndex(u => u.id === id);
本文标签: angularHow to use quotindexOfquot in javascriptStack Overflow
版权声明:本文标题:angular - How to use "indexOf" in javascript - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743979819a2571031.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论