我一直在尝试对角度2应用程序执行测试,单击调用函数的提交按钮.我通常使用两种方法来执行相同的操作.
element.nativeElement.click()
和
element.triggerEventHandler('click',null);
我认为这两种方法都是一样的,直到我遇到触发事件处理程序方法不起作用的情况.
element = fixture.debugElement.query(By.css('.dropList li')); element.triggerEventHandler('click',null); //Click event works here fixture.detectChanges(); let button = fixture.debugElement.query(By.css('button')); //button.triggerEventHandler('click',null); //Does not call function button.nativeElement.click(); //Calls function fixture.detectChanges();
模板供您参考:
<form (ngSubmit)="printSelection()"> <div class="dropList"> <ul> <li *ngFor="let element of data.elements" (click)="selectElement(element)"> </li> </ul> </div> <button type="submit">Submit</button> </form>
element.nativeElement.click()
是native method来模拟鼠标单击元素.它冒泡,它的行为方式与点击元素的方式相同.
debugElement.triggerEventHandler(eventName,eventObj)
是角度内置方法,它只调用当前调试元素上给定eventName的所有侦听器:
triggerEventHandler(eventName: string,eventObj: any) { this.listeners.forEach((listener) => { if (listener.name == eventName) { listener.callback(eventObj); } }); }
当DebugRenderer2运行listen方法时添加监听器:
listen( target: 'document'|'windows'|'body'|any,eventName: string,callback: (event: any) => boolean): () => void { if (typeof target !== 'string') { const debugEl = getDebugNode(target); if (debugEl) { debugEl.listeners.push(new EventListener(eventName,callback)); } } return this.delegate.listen(target,eventName,callback); }
它发生在我们将事件绑定应用于元素之类的时候
>(click)=“handler()”
> @HostListener(‘click’)
>主持人:'{‘(mouseenter):’handler()’}
> renderer.listen
假设我们有以下模板:
<div (click)="test()"> <div class="innerDiv"> {{title}} </div> </div>
我们的测试看起来像:
de = fixture.debugElement.query(By.css('.innerDiv')); de.nativeElement.click(); // event will be bubbled and test handler will be called de.triggerEventHandler('click',null); // there is not handlers for click event // that angular added to this element // so test method won't be called
然后让我们看看你的模板.按钮没有处理程序,因此triggerEventHandler不会产生任何影响.另一方面button.nativeElement.click();将触发提交,因为按钮具有类型提交及其在点击事件上的按钮的标准行为.