Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/unit-testing/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Angular nativeElement.click()和事件处理程序';点击?_Angular_Unit Testing_Typescript_Karma Jasmine - Fatal编程技术网

Angular nativeElement.click()和事件处理程序';点击?

Angular nativeElement.click()和事件处理程序';点击?,angular,unit-testing,typescript,karma-jasmine,Angular,Unit Testing,Typescript,Karma Jasmine,我一直在尝试为angular 2应用程序执行一个测试,该应用程序单击一个调用函数的提交按钮。我通常使用两种方法来执行相同的操作 element.nativeElement.click() 及 我认为这两种方法是相同的,直到我遇到触发事件处理程序方法不起作用的情况 element = fixture.debugElement.query(By.css('.dropList li')); element.triggerEventHandler('click',null); //Click eve

我一直在尝试为angular 2应用程序执行一个测试,该应用程序单击一个调用函数的提交按钮。我通常使用两种方法来执行相同的操作

element.nativeElement.click()

我认为这两种方法是相同的,直到我遇到触发事件处理程序方法不起作用的情况

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()

是模拟鼠标单击图元。它在冒泡,它的行为方式与我们单击元素时的行为方式相同

debugElement.triggerEventHandler(eventName,eventObj)

是一种内置方法,仅调用当前调试元素上给定eventName的所有侦听器:

triggerEventHandler(eventName: string, eventObj: any) {
  this.listeners.forEach((listener) => {
    if (listener.name == eventName) {
      listener.callback(eventObj);
    }
  });
}
debugrender2
运行
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);
}
当我们将事件绑定应用到类似

  • (单击)=“handler()”
  • @HostListener('click')
  • host:“{”(鼠标指针):“handler()”}
  • renderer.收听
假设我们有以下模板:

<div (click)="test()">
  <div class="innerDiv">
     {{title}}
  </div>
</div>

然后让我们看看你的模板。没有用于
按钮的处理程序,因此
triggerEventHandler
不会有任何效果。另一方面,
button.nativeElement.click()
将触发submit,因为按钮的类型为submit,它的标准行为为单击按钮事件。

您可以添加组件的模板吗?@yurzui添加了模板…谢谢。模板中的
按钮在哪里?很好的解释!非常感谢。
<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