San*_*nju 9 unit-testing typescript karma-jasmine angular
我一直在尝试对角度2应用程序执行测试,单击调用函数的提交按钮.我通常使用两种方法来执行相同的操作.
element.nativeElement.click()
Run Code Online (Sandbox Code Playgroud)
和
element.triggerEventHandler('click',null);
Run Code Online (Sandbox Code Playgroud)
我认为这两种方法都是一样的,直到我遇到触发事件处理程序方法不起作用的情况.
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();
Run Code Online (Sandbox Code Playgroud)
模板供您参考:
<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>
Run Code Online (Sandbox Code Playgroud)
那么,这两种方法之间有什么区别,或者您认为我的代码中某处可能出错?
yur*_*zui 14
element.nativeElement.click()
是模拟鼠标单击元素的本机方法.它冒泡,它的行为方式与点击元素的方式相同.
debugElement.triggerEventHandler(eventName,eventObj)
是角度内置方法,它只调用当前调试元素上给定eventName的所有侦听器:
triggerEventHandler(eventName: string, eventObj: any) {
this.listeners.forEach((listener) => {
if (listener.name == eventName) {
listener.callback(eventObj);
}
});
}
Run Code Online (Sandbox Code Playgroud)
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);
}
Run Code Online (Sandbox Code Playgroud)
它发生在我们将事件绑定应用于元素之类的时候
(click)="handler()" @HostListener('click') host: '{ '(mouseenter): 'handler()' } renderer.listen假设我们有以下模板:
<div (click)="test()">
<div class="innerDiv">
{{title}}
</div>
</div>
Run Code Online (Sandbox Code Playgroud)
我们的测试看起来像:
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
Run Code Online (Sandbox Code Playgroud)
然后让我们看看你的模板.没有处理程序,button所以triggerEventHandler不会有任何影响.另一方面button.nativeElement.click();将触发提交,因为按钮具有类型提交及其在点击事件上的按钮的标准行为.
| 归档时间: |
|
| 查看次数: |
5600 次 |
| 最近记录: |