javascript - 如何在 Angular 4 中删除数据后刷新 mfData

标签 javascript angular typescript refresh angular-datatables

我使用 mfDataTable 在 UI 中表示我的数据。我在每一行上都有一个按钮,用于删除该行。从组件中的数组中删除数据可以正常工作,但表不会刷新。我向您展示了我的代码,请给我一些提示,我在哪里犯了错误,以及如何仅刷新 UI 上的表格!

mfDataTable 来自:

import { DataTableModule } from "angular2-datatable";

我的服务类,保存修复数据:

@Injectable()
export class AgentsService {
  agentsData = [{
    'id': 1,
    'agentCountry': 40,
    'agentName': 'New Agent',
    'agentNumber': 246
  },
   {...more agents...}
  ];

  removeAgentByAgentId(agent: any): void {
    let index: number = this.agentsData.indexOf(agent);
    if (index !== -1) {
      this.agentsData.splice(index, 1);
    }
  }
}

HTML 部分,其中表格由 mfDataTable 定义:

<table class="table table-striped" [mfData]="agentsData | agentsDataFilterByCountry : filterByCountry" #mf="mfDataTable" [mfRowsOnPage]="rowsOnPage"
    [(mfSortBy)]="sortBy" [(mfSortOrder)]="sortOrder">
    <thead>
        <tr>
            <th style="width: 15%">Actions</th>
            <th style="width: 20%">
                <mfDefaultSorter by="agentName">Name</mfDefaultSorter>
            </th>
            <th style="width: 5%">
                <mfDefaultSorter by="agentNumber">Number</mfDefaultSorter>
            </th>
            <th style="width: 10%">
                <mfDefaultSorter by="agentCountry">Country</mfDefaultSorter>
            </th>
        </tr>
    </thead>
    <tbody>
        <tr *ngFor="let agent of mf.data; let i = index" [attr.data-index]="i">
            <td>
                <button (click)="onDeleteConfirm(agent)" class="btn btn-danger ion-trash-a"></button>
            </td>
            <td>{{agent.agentName}}</td>
            <td>{{agent.agentNumber}}</td>
            <td>{{agent.agentCountry}}</td>
        </tr>
    </tbody>
</table>

还有组件,我在其中实现了 OnChangesngOnChanges 方法没有记录任何内容,并且不刷新数据表:

import { Component, OnInit, OnChanges, SimpleChange, Input } from '@angular/core';
import { AgentsService } from '../../services/agents/agents.service';

@Component({
  selector: 'app-agents',
  templateUrl: './agents.component.html',
  styleUrls: ['./agents.component.scss']
})
export class AgentsComponent implements OnInit, OnChanges {

  private service: AgentsService;
  agentsData: Array<any>;
  filterByCountry = "40";
  rowsOnPage = 10;
  sortBy = "agentName";
  sortOrder = "asc";

  constructor(service: AgentsService) {
      this.service = service;
      this.agentsData = service.agentsData;
  }

  ngOnInit() {
  }

  ngOnChanges(changes: {[propKey: string]: SimpleChange}) {
    console.log("something changed");//not logging anything... :(
  }

  onDeleteConfirm(agent: any): void {
    if (window.confirm('Are you sure you want to delete?')) {
      console.log("agentsData before remove: "+this.agentsData.length);
      this.service.removeAgentByAgentId(agent);
      this.agentsData = service.agentsData;
      console.log("agentsData after remove: "+this.agentsData.length);
    }
  }
}

onDeleteConfirm方法中,日志清楚地显示删除之前和之后,它删除了选定的代理。但不刷新表。我应该如何刷新它?谢谢!

最佳答案

您应该清除您的收藏。在组件中使用以下内容:

this.agentsData = new Array<any>();
this.agentsData = this.service.getAgentData();

在服务中创建 getter 方法后

或者

this.agentsData = new Array<any>();
this.agentsData = this.agentsData.concat(this.service.agentsData);

也会做同样的事情。

关于javascript - 如何在 Angular 4 中删除数据后刷新 mfData,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45920049/

相关文章:

javascript - 从 AngularJS 访问全局变量

javascript - 如何使用 JSON 从 REST API 选择的对象中检索值?

javascript - 范围错误: Invalid status code: 0 node js

JavaScript 推送返回一个空数组

javascript - "echarts"' has no exported member named ' EChartOption '. Did you mean ' EChartsOption' 代替?

javascript - 我如何像 Java 包一样组织我的 Angular 应用程序文件夹?

Angular 2. 依赖于服务器响应的防护

Angular 2 RC 5 - Observable.interval 触发变化检测

javascript - 从 Node_Modules(带有 TypeScript 的 .Net Core 项目) bundle/复制 Javascript 库

TypeScript - 如何过滤对象?