Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
152 views
in Technique[技术] by (71.8m points)

Removing specific item in cart angular 10

What am I missing here? I just want to delete the specific item but it's deleting the last item on my list if I have more than 1 item.

This is what I have on my service:

//cartService.ts

 removeItem(index){
      this.items.splice(this.items.indexOf(index), 1); //this is the problem
  }

This is my component:

 //cartComponent.ts

removeItem(index) {
     this.cartService.removeItem(index);
}

And my html:

// cart.html 

<div  class="col-12 " *ngFor="let addedItem of items; let index = index  ">
  <ul>
     <li> {{addedItem.name }}  <button class="btn" (click)="removeItem(index)"> delete </button> </li>
  </ul>
</div>
question from:https://stackoverflow.com/questions/65840393/removing-specific-item-in-cart-angular-10

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

Following changes should work.

HTML:

<div  class="col-12 " *ngFor="let addedItem of items; let i = index ">
  <ul>
     <li> {{addedItem.name }}  <button class="btn" (click)="removeItem(i)"> delete </button> </li>
  </ul>
</div>

cartComponent.ts

removeItem(index: number) {
     this.cartService.removeItem(index);
}

cartService.ts

removeItem(index: number){
      this.items.splice(index, 1);
  }

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...