मैं कोणीय 2 में संग्रहित सरणी से एक आइटम हटाना चाहता हूं, टाइप स्क्रिप्ट के साथ। मैं डेटा सेवा, डेटा सेवा कोड नामक एक सेवा का उपयोग कर रहा हूं :
export class DataService {
private data: string[] = [];
addData(msg: string) {
this.data.push(msg);
}
getData() {
return this.data;
}
deleteMsg(msg: string) {
delete [this.data.indexOf(msg)];
}
}
और मेरा घटक वर्ग:
import {Component} from '@angular/core'
import {LogService} from './log.service'
import {DataService} from './data.service'
@Component({
selector: 'tests',
template:
`
<div class="container">
<h2>Testing Component</h2>
<div class="row">
<input type="text" placeholder="log meassage" #logo>
<button class="btn btn-md btn-primary" (click)="logM(logo.value)">log</button>
<button class="btn btn-md btn-success" (click)="store(logo.value)">store</button>
<button class="btn btn-md btn-danger" (click)="send()">send</button>
<button class="btn btn-md " (click)="show()">Show Storage</button>
<button (click)="logarray()">log array</button>
</div>
<div class="col-xs-12">
<ul class="list-group">
<li *ngFor="let item of items" class="list-group-item" #ival>
{{item}}
<button class="pull-right btn btn-sm btn-warning" (click)="deleteItem(ival.value)">Delete
</button>
</li>
</ul>
</div>
<h3>{{value}}</h3>
<br>
</div>
`
})
export class TestsComponent {
items: string[] = [];
constructor(
private logService: LogService,
private dataService: DataService) {
}
logM(message: string) {
this.logService.WriteToLog(message);
}
store(message: string) {
this.dataService.addData(message);
}
send(message: string) {
}
show() {
this.items = this.dataService.getData();
}
deleteItem(message: string) {
this.dataService.deleteMsg(message);
}
logarray() {
this.logService.WriteToLog(this.items.toString());
}
}
जब मैं किसी आइटम को हटाने का प्रयास करता हूं, तो उसे छोड़कर, अब सब कुछ अच्छा चल रहा है। लॉग मुझे दिखाता है कि आइटम अभी भी सरणी में है, और इसलिए अभी भी पृष्ठ पर दिखाया गया है। डिलीट बटन के साथ चुनने के बाद मैं आइटम को कैसे हटा सकता हूं ??
indexOf()के लिए-1, यह है जब सरणी से पिछले आइटम को हटा देगाmsgनहीं मिला था!