首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Ember.js,我如何手动将模板和视图的作用域设置为其相应的控制器?

使用Ember.js,我如何手动将模板和视图的作用域设置为其相应的控制器?
EN

Stack Overflow用户
提问于 2012-11-16 09:45:14
回答 1查看 630关注 0票数 3

假设我启动了一个控制器:

代码语言:javascript
复制
    App.pageController = Ember.Controller.create({

         pageNumber:  '12',
    })

及其对应的视图:

代码语言:javascript
复制
    App.pageView = Ember.View.create({

        templateName: 'page-template',

    }).append();

现在是它的模板:

代码语言:javascript
复制
    <script type="text/x-handlebars" data-template-name = 'page-template'>
        <div class = 'page-background'>
            page: {{ pageNumber }}
        </div>
    </script>

我打算让pageController为pageView提供呈现上下文,但是我不知道如何显式地为此提供指令,因此没有呈现pageNumber。

我可以通过在pageView中放置一个pageNumberBinding来绕过这个问题:

代码语言:javascript
复制
   App.pageView = Ember.View.create({

        templateName: 'page-template',
        pageNumberBinding: 'App.pageController.pageNumber',

    }).append();

并重写模板,如下所示

代码语言:javascript
复制
 page: {{ pageNumber contextBinding="this" }}

但是换种方式你会怎么做呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-11-16 09:55:53

通过在视图上设置controller属性,视图将把它不知道的属性转发给控制器。

因此,使用您的示例,您可以这样做:

代码语言:javascript
复制
App.pageView = Ember.View.create({
    controller:   App.pageController,
    templateName: 'page-template',
}).append();

看看Ember docs for Ember.Viewintroduction on their site吧。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13409218

复制
相关文章

相似问题

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