javascript – Angular 2使函数在ng-content中可用

我有一个带有这样的模板的下拉列表:

<div class="dropdown-trigger" (click)="contentToggle()">
     <ng-content select="dropdown-trigger"></ng-content>
</div>
<div class="dropdown-content" *ngIf="showContent">
     <ng-content select="dropdown-content"></ng-content>
</div>

我希望能够在ng-content中使用contentToggle(),以便我可以使用其他元素来关闭下拉列表,例如我可能需要一个关闭按钮…这是什么最好的办法吗?

解决方法:

这样就可以了:

<dropdown #dropdown>
  <button dropdownTrigger (click)="dropdown.toggleDropdown()">Click me</button>
</dropdown>

您只需将一个本地模板变量分配给组件,即可访问组件中的所有内容.包括您要调用的功能.

请注意,您应该/还需要将选择位更改为:

<ng-content select="[dropdownTrigger]"></ng-content>
<ng-content select="[dropdownContent]"></ng-content>

相关文章

ANGULAR.JS:NG-SELECTANDNG-OPTIONSPS:其实看英文文档比看中...
AngularJS中使用Chart.js制折线图与饼图实例  Chart.js 是...
IE浏览器兼容性后续前言 继续尝试解决IE浏览器兼容性问题,...
Angular实现下拉菜单多选写这篇文章时,引用文章地址如下:h...
在AngularJS应用中集成科大讯飞语音输入功能前言 根据项目...
Angular数据更新不及时问题探讨前言 在修复控制角标正确变...