angular组件传值 输入输出

还是利用tabbar来介绍,上代码

<app-scrollable-tab
  [menus]="topMenus"
  (tabSelected)="handleTabSelected($event)"
></app-scrollable-tab>

组件内部js

  selectedIndex = -1;
  @Input() menus: TopMenu[] = [];
  @Output() tabSelected = new EventEmitter();
  constructor() { }

  ngOnInit() {
  }

  handleSelection(index: number) {
    this.selectedIndex = index;
    this.tabSelected.emit(this.menus[this.selectedIndex]);
  }

menus未输入 tabselected为输出

对应h5页面

<ul>
  <li *ngFor="let menu of menus; let i = index">
    <a href="#" [class.active]="i === selectedIndex" (click)="handleSelection(i)">
      {{ menu.title }}
    </a>
    <span class="indicator" *ngIf="i === selectedIndex else otherDisplay"></span>
    <ng-template #otherDisplay>
      未选中
    </ng-template>
  </li>
</ul>

output为输出属性 topbar内部点击事件处理,handleselection将选中的index传向外部组件。利用emit函数将选中的对应menu值到根组件。根组件js文件输出

  handleTabSelected(topMenu: TopMenu) {
    console.log(topMenu);
  }

点击之后效果如下:

源码地址:

https://github.com/lee727n/angularLearning

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值