首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Angular2 EventEmitter不工作且无错误

Angular2 EventEmitter不工作且无错误
EN

Stack Overflow用户
提问于 2016-09-26 04:51:07
回答 1查看 893关注 0票数 0

我试图发出一个简单的事件,但我不能让它工作。

代码语言:javascript
复制
import {Component, Input, Output, EventEmitter} from '@angular/core'
import {MenuService} from "./menu.service";


    @Component({
        selector:'side-menu',
        templateUrl:'component.html',
    })

    export class SideMenuComponent {

        @Output() pinnedChange:EventEmitter<any> = new EventEmitter();

        //Show and Hide the Detail Pane
        detailPanePinned = false;
        detailPaneVisible = false;

        pinMenuClick(){
            this.detailPanePinned = !this.detailPanePinned;
            this.detailPaneVisible = !this.detailPaneVisible;

            this.pinnedChange.emit({
                detailPanePinned: this.detailPanePinned
            })

        }

    }

下面是我正在尝试监听的HTML

代码语言:javascript
复制
<side-menu class="side-block pull-left">

</side-menu>
<design-pane (change)="onPinnedChange($event)"></design-pane>
<side-menu class="side-block pull-right">
</side-menu>

下面是上述html的组件。

代码语言:javascript
复制
import {Component} from '@angular/core'

@Component({
    selector:'builder-layout',
    templateUrl:'app/builder/layout/layout.component.html'
})

export class BuilderLayoutComponent {

    onPinnedChange($event){
        console.log($event)
    }
}

当我点击pinMenuClick时,我没有得到任何错误。它就是打不中我的onPinnedChange()

我使用的是Angular2 2.0.0官方版

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-09-26 05:20:35

我相信只有发出事件的组件才能监听它,在您的情况下,就是侧边菜单。所以你需要这样做:

代码语言:javascript
复制
<side-menu (pinnedChange)="onPinnedChange($event)"></side-menu>
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39691728

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档