我一直在尝试对角度2应用程序执行测试,单击调用函数的提交按钮.我通常使用两种方法来执行相同的操作.
@H_404_18@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>