gpt4 book ai didi

javascript - CRUD 后重新加载页面

转载 作者:行者123 更新时间:2023-12-02 22:51:21 26 4
gpt4 key购买 nike

我正在寻找一种对用户透明的 CRUD 操作后重新加载页面的方法。

实际上,在创建或删除之后,我必须重新加载页面才能显示我的操作。

我使用 api 来实现这个,当我将它与 json 文件一起使用时,它工作正常。

谢谢

删除示例:

  dataSource = new MatTableDataSource();
displayedColumns = ['first_name', 'middle_name', 'last_name', 'mail', 'role', 'action'];
action: any;
selectedUser: User;
@Input() user: User;
data: any;


@ViewChild(MatSort, {static: true}) sort: MatSort;
@ViewChild(MatPaginator, {static: true}) paginator: MatPaginator;

constructor(private formBuilder: FormBuilder, private userService: UserService, public dialog: MatDialog) {
}

ngOnInit() {
this.dataSource.sort = this.sort;
this.dataSource.paginator = this.paginator;

this.userService.getUsers()
.subscribe(
(response) => {
this.dataSource.data = response;
},
(error) => {
console.log('error ' + error);
}
);
}

onDelete(selectedUser){
Swal.fire({
title: 'Are you sure?',
text: "You won't be able to revert this!",
type: 'warning',
showCancelButton: true,
confirmButtonColor: '#3085d6',
cancelButtonColor: '#d33',
confirmButtonText: 'Yes, delete it!'
}).then((result) => {
if (result.value) {
this.userService.delete(selectedUser.id).subscribe(res => {
this.dataSource.data.splice(selectedUser.id, 1);
});
Swal.fire(
'Deleted!',
'User has been deleted.',
'success'
)
}
})
}

html代码

让我知道您是否需要更多代码以及代码的哪一部分。

  <div class="mat-elevation-z8">
<table mat-table [dataSource]="dataSource" matSort multiTemplateDataRows >

<!-- First name Column -->
<ng-container matColumnDef="first_name">
<th mat-header-cell *matHeaderCellDef mat-sort-header> First name </th>
<td mat-cell *matCellDef="let element"> {{element.first_name}} </td>
<label>
<input class="table-input" *ngIf="selectedUser" type="text">
</label>
</ng-container>

<!-- Middle name Column -->
<ng-container matColumnDef="middle_name">
<th mat-header-cell *matHeaderCellDef mat-sort-header>Middle name </th>
<td mat-cell class="status" *matCellDef="let element">{{element.middle_name}}</td>
</ng-container>

<!-- Last name Column -->
<ng-container matColumnDef="last_name">
<th mat-header-cell *matHeaderCellDef mat-sort-header> Last name </th>
<td mat-cell *matCellDef="let element"> {{element.last_name}} </td>
</ng-container>

<!-- Email Column -->
<ng-container matColumnDef="mail">
<th mat-header-cell *matHeaderCellDef mat-sort-header> Email </th>
<td mat-cell *matCellDef="let element"> {{element.mail}} </td>
</ng-container>

<!-- Role Column -->
<ng-container matColumnDef="role">
<th mat-header-cell *matHeaderCellDef mat-sort-header> Role </th>
<td mat-cell *matCellDef="let element"> {{getRole(element)}} </td>
</ng-container>

<!-- Actions Column -->
<ng-container matColumnDef="action">
<th mat-header-cell *matHeaderCellDef mat-sort-header> Actions </th>
<td mat-cell *matCellDef="let row">
<button mat-raised-button color="primary" class="editUserBtn" (click)="openEditDialog(row)"><mat-icon class="edit-icon" >launch</mat-icon><span>Edit</span></button>
<button mat-raised-button color="warn" class="deleteUserBtn" (click)="onDelete(row)"><mat-icon class="delete-icon" >delete_outline</mat-icon><span>Delete</span></button>
</td>
</ng-container>

<tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
<tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
</table>
<mat-paginator [pageSize]="5" [pageSizeOptions]="[5, 10, 15]" showFirstLastButtons></mat-paginator>
</div>
</div>

最佳答案

在这种情况下,您必须使用BehaviorSubjectBehaviorSubject 持续监听订阅者,并在有 next 发出时进行更新。

dataSource: BehaviorSubject<MatTableDataSource[]> = new BehaviorSubject([]);

onDelete(selectedUser) {
Swal.fire({
title: 'Are you sure?',
text: "You won't be able to revert this!",
type: 'warning',
showCancelButton: true,
confirmButtonColor: '#3085d6',
cancelButtonColor: '#d33',
confirmButtonText: 'Yes, delete it!'
}).then(result => {
if (result.value) {
this.userService.delete(selectedUser.id).subscribe(res => {
this.dataSource.value.data.splice(selectedUser.id, 1);
this.dataSource.next(this.dataSource.value);
});
Swal.fire('Deleted!', 'User has been deleted.', 'success');
}
});
}

其中 MatTableDataSource 应该是您的数据类型。

关于javascript - CRUD 后重新加载页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58174676/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com