Angular 6-检查后表达式已更改 [英] Angular 6 - Expression has changed after it was checked
问题描述
我不熟悉Angle,并尝试与 easyui angular 结合.
I am new to angular and trying to combine with easyui angular.
我在尝试打开/关闭对话框时发现此错误:
I found this error when trying to open/close dialog:
错误错误:ExpressionChangedAfterItHasBeenCheckedError:检查表达式后,表达式已更改.上一个值:'klass:l-btn f-inline-row f-content-center l-btn-small l-btn-focus".当前值: "klass:l-btn f-inline-row f-content-center l-btn-small".
ERROR Error: ExpressionChangedAfterItHasBeenCheckedError: Expression has changed after it was checked. Previous value: 'klass: l-btn f-inline-row f-content-center l-btn-small l-btn-focus'. Current value: 'klass: l-btn f-inline-row f-content-center l-btn-small'.
这是我的代码.
user.component.html
<eui-linkbutton (click)="addAction()" iconCls="icon-add" style="margin-bottom:10px">Add New</eui-linkbutton>
<eui-datagrid
[data]="users" style="height1:250px" [filterable]="true"
[selectionMode]="'single'"
[(selection)]="rowSelected"
[euiContextMenu]="contextMenu"
>
</eui-datagrid>
<!-- contextmenu -->
<eui-menu #contextMenu (itemClick)="contextClick($event)">
<eui-menu-item value="edit" text="Edit"></eui-menu-item>
<eui-menu-item text="Delete"></eui-menu-item>
<eui-menu-item text="View"></eui-menu-item>
</eui-menu>
<eui-dialog #formDialog [closed]="closed" [draggable]="true" [modal]="true" [title]="isNewRow ? 'Add' : 'Edit'" (close)="closed=true">
<div class="dialog-button">
<eui-linkbutton [disabled]="!formObj.valid" (click)="saveAction()" style="width:80px">Save</eui-linkbutton>
<eui-linkbutton (click)="formDialog.close()" style="width:80px">Cancel</eui-linkbutton>
</div>
</eui-dialog>
user.component.ts
export class UserComponent implements OnInit {
rowSelected = null;
formObj: FormGroup;
constructor(public userService: UserService, fb: FormBuilder){
}
get row(){
return this.rowSelected;
}
set row(value: any){
this.rowSelected = value;
this.formObj.reset(this.rowSelected);
}
editAction(row){
this.row = this.rowSelected;
this.closed = false;
}
addAction(){
console.log('open babe');
this.row = {
'id' : null,
'username' : null,
'password' : null,
'email' : null,
'first_name' : null,
'last_name' : null
};
this.closed = false;
}
isNewRow = false;
editingRow = null;
closed = true;
users: Object;
currentSelection = null;
ngOnInit() {
this.userService.getData().subscribe(
data => this.users = data
)
console.log('ngoninit');
this.initRow();
this.closed = true;
}
initRow() {
this.editingRow = {
username: null,
password: null,
email: null,
first_name: null,
last_name: null,
};
}
onAddRow() {
console.log('open babe');
this.initRow();
this.isNewRow = true;
this.closed = false;
}
onEditRow(row) {
this.isNewRow = false;
this.editingRow = row;
this.closed = false;
}
contextClick(value){
if(!this.rowSelected){
alert('Please select a row first!');
}
else{
if(value == 'edit'){
this.editAction(this.rowSelected);
}
}
}
}
我已经搜索了许多教程来解决此问题,但似乎该教程的条件与我的不匹配.
I have search many tutorial to fix this problem but it seems like the tutorial condition doesn't match with mine.
我是否误解或缺少一些有关角度的实用知识? 什么是更新属性的正确方法?
Do i misunderstand something or missing something practical about angular? what is the proper way to update attribute?
推荐答案
使用ChangeDetectorRef
服务检测新更改
当视图使用OnPush
(checkOnce)更改检测策略时,将视图明确标记为已更改,以便可以再次对其进行检查.
When a view uses the OnPush
(checkOnce) change detection strategy, explicitly marks the view as changed so that it can be checked again.
import { Component, Input, ChangeDetectionStrategy,ChangeDetectorRef } from '@angular/core';
@Component({
selector: 'component',
templateUrl: 'component.html',
changeDetection: ChangeDetectionStrategy.OnPush
})
constructor(cdRef:ChangeDetectorRef){}
ngAfterViewInit() {
this.cdRef.detectChanges();
}
这篇关于Angular 6-检查后表达式已更改的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!