Ember.js:从嵌套路由调用ApplicationRoute的操作

时间:2013-11-01 09:59:49

标签: ember.js coffeescript

假设我有ApplicationRoute动作goBack(正如您在评论中看到的那样,由于不同移动浏览器中的错误,我需要自己处理goBack):

Mobile.ApplicationRoute = Em.Route.extend
    actions:
        goBack: ->
            # TODO: Remove when iOS 7 fixed their history
            # If there's no route to go back, go to front
            # TODO: Remove when Microsoft fixed their
            # back button in offline mode
            if not (Nn.MobileHelper.isiPhone() or Nn.MobileHelper.isIeMobile()) and @get("router.recentRoute")?
                return window.history.back()

            @get("controller").set("isHitBackButton", true)

            @transitionTo("front").then => @get("controller").set("isHitBackButton", false)

如何从其他路线触发此操作?请注意,由于我需要调用@transitionTo,因此这段代码必须位于路径中。

1 个答案:

答案 0 :(得分:5)

默认情况下,操作会冒泡到应用程序路径!只需在模板中使用{{action 'goBack'}},或从代码(减去组件)中调用this.send('goBack')即可。从组件中,您需要将事件调用连接起来稍微不同,并使用this.sendAction('internalActionName')

http://emberjs.jsbin.com/ulIhUze/1/edit