gpt4 book ai didi

Angular 4 ngModel 在测试输入更改后未更新

转载 作者:行者123 更新时间:2023-12-04 17:51:48 24 4
gpt4 key购买 nike

我有一个简单的应用程序,它有 1 个输入:

@Component({   selector: 'mycomponent',   styles: [

], template: `
<div class="new-stuff">
<div>
<div>
Name: <input type="text" class="new-stuff-name" [(ngModel)]="stuff.name"/>
</div>
<div class="new-stuff-name-error" *ngIf="nameError != null">
{{nameError}}
</div>
</div>

<button class="new-stuff-save" (click)="checkStuff()">Add idea</button>
</div> `, })
export class StuffComponent implements OnInit {
public stuff = {name: ''};
public allStuff = [];
public checkStuff() {
if (this.stuff.name.length === 0) {
this.nameError = 'The name field cannot be empty';
}

if (this.stuff.name.length > 0) {
this.allStuff.push(this.stuff);
this.stuff= { name: ''};
}
}
}

当我运行应用程序时,我看到值发生变化并且一切看起来都捆绑在一起,但是当我尝试测试当我更改输入框中的值并单击按钮时,错误消息没有显示错误消息仍然存在显示是因为输入值没有改变。

这是我的 Jasmine 测试:

describe(`stuff`, () => {
let comp: StuffComponent ;
let fixture: ComponentFixture<StuffComponent>;

beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [StuffComponent ],
schemas: [NO_ERRORS_SCHEMA],
imports: [FormsModule],
}).compileComponents();
fixture = TestBed.createComponent(StuffComponent );
comp = fixture.componentInstance;
}));

describe('adding a new stuff', () => {
let stuffNameInput;
let saveButton;
beforeEach(() => {
stuffNameInput = fixture.nativeElement
.querySelectorAll('.new-stuff-name')[0];
saveButton = fixture.debugElement.nativeElement.querySelector(
'.new-stuff-save');
});

describe('when is successfull', () => {
beforeEach(async(() => {
stuffNameInput.value = 'New Stuff';
stuffNameInput.dispatchEvent(new Event('input'));
saveButton.click();
fixture.detectChanges();
}));
it('should display an error', () => {
let errorDiv = fixture.nativeElement
.querySelectorAll('.new-stuff-desc-error');
expect(errorDiv.length)
.toBe(0, 'Error message displayed');
});
});
});
});

我尝试了多种方法,将 async 替换为 fakeAsync,调用 tick 函数,将点击移动到 fixture.whenStable().then block 内,将 div 的检查移动到 fixture.whenStable().then block 。到目前为止没有任何效果。

我正在使用 Angular 的 4.1.3 版本

最佳答案

回答我自己的问题以记录问题。

将 stuff.name 用作 ngModel 效果不佳。

我将 stuff.name 更改为 name,它开始工作了

关于Angular 4 ngModel 在测试输入更改后未更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44113739/

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