加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angular – nativeElement.click()和事件处理程序的点击有什么区

发布时间:2020-12-17 10:16:40 所属栏目:安全 来源:网络整理
导读:我一直在尝试对角度2应用程序执行测试,单击调用函数的提交按钮.我通常使用两种方法来执行相同的操作. element.nativeElement.click() 和 element.triggerEventHandler('click',null); 我认为这两种方法都是一样的,直到我遇到触发事件处理程序方法不起作用的
我一直在尝试对角度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();将触发提交,因为按钮具有类型提交及其在点击事件上的按钮的标准行为.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读