Angular单元测试之事件触发的实现
=在angular项目中时常有一些click、input、focusout等事件操作,那么如何在单元测试中触发这些事件呢?
一、触发Click事件
//方法一 constele=fixture.debugElement.query(By.css("#id")); ele.triggerEventHandler('click',null) fixture.detectChanges();//更新视图 //方法二 constele=fixture.nativeElement.querySelector("#id"); ele.click(); fixture.detectChanges();//更新视图
二、触发input事件
触发input事件,需要在获取到input元素后,先给输入框绑定值,然后去触发输入事件,最后更新视图。
constinput=fixture.nativeElement.querySelector("#input"); input.value='abc'; input.dispatchEvent(newEvent('input')); fixture.detectChanges();//更新视图
二、触发focusout事件
constinput=fixture.nativeElement.querySelector("#input"); input.dispatchEvent(newEvent('focusout')); fixture.detectChanges();//更新视图
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。