backbone.js - 使用 backbone.marionette 获取 "NoTemplateError: Could not find template"

标签 backbone.js coffeescript marionette

在我尝试编写的这个 coffeescript+backbone.marionette 应用程序中,当我尝试在我的内容区域中显示不同的 View 时,我收到“NoTemplateError:找不到模板:‘#second-template’”。

下面是两段代码,是基于David Sulc's Backbone Books tutorial . WelcomeApp 显示正常,但是当我单击然后调用 MyApp.SecondApp.display() 的菜单项时,我得到了 NoTemplateError。

window.MyApp = MyApp = new Backbone.Marionette.Application()

MyApp.addRegions
  menu: '#menu'
  content: '#content'

class MyApp.MenuView extends Backbone.Marionette.View
  el: '#menu'

  events:
    'click #get-second': 'showSecond'

  showSecond: ->
    MyApp.SecondApp.display()

MyApp.vent.on 'welcome:rendered', ->
  menu = new MyApp.MenuView()
  MyApp.menu.attachView(menu)


MyApp.WelcomeApp = do ->
  WelcomeApp = {}

  class WelcomeLayout extends Backbone.Marionette.Layout
    template: '#content_welcome-template'

  WelcomeApp.display = ->
    WelcomeApp.layout = new WelcomeLayout()

    WelcomeApp.layout.on 'show', ->
      MyApp.vent.trigger 'welcome:rendered'

    MyApp.content.show MyApp.WelcomeApp.layout

  return WelcomeApp


MyApp.SecondApp = {}

class MyApp.SecondApp.WelcomeView extends Backbone.Marionette.ItemView
  template: '#second-template'

MyApp.SecondApp.display = ->
  welcomeView = new MyApp.SecondApp.WelcomeView()
  MyApp.content.show welcomeView

MyApp.addInitializer ->
  MyApp.WelcomeApp.display()

我的模板只是 index.html 中的脚本 block 。实际上,我将 WelcomeApp 使用的模板与 SecondApp 使用的模板进行了交换,当我这样做时 WelcomeApp 可以很好地找到“#second-template”。

我在 backbone.marionette 0.9.10 和 0.9.11 上都试过了。

如有任何帮助,我们将不胜感激!

最佳答案

感谢两位对我的问题发表评论的人。在剥离 HTML 和 coffeescript 代码时,我注意到我的 HTML 中的一个 div 使用 <div> 错误地关闭了。 .一旦我将其固定为 </div>一切正常。愚蠢的错误,但直到我将 HTML 剥离得足够多以至于它就在我面前时,我才看到它。我需要更好的语法检查。

关于backbone.js - 使用 backbone.marionette 获取 "NoTemplateError: Could not find template",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12000301/

相关文章:

javascript - 使用带有 Backbone.js 的 POST 方法发送数据

jquery - 我可以将 jQuery pjax 与backbone.js 一起使用吗

backbone.js - 渲染封闭的 Marionette View

javascript - 获取点击事件的ui元素信息

javascript - Backbone.js 属性/获取似乎很有趣

javascript - clearTimeout 动态更新定时器

javascript - 解析 HTML 表中的值

javascript - Node.js:如何为 prod 和 staging 设置不同的变量

javascript - 在 coffeescript 文件中使用 erb 更改背景

javascript - browserify可以设置全局模块吗?