- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近读了很多关于 emberjs 的文章,但有些事情对我来说并不是很清楚:我有一种感觉,渲染模板有不同的方式。有人可以解释一下它们之间的区别吗:
{{render}}
{{partial}}
{{template}}
{{outlet}}
我正在使用 pre4,因此如果其中一些关键字已过时,请通知。
最佳答案
您可以通过搜索:Ember.Handlebars.registerHelper('?'
在 Ember.JS 源中搜索所有这些内容。 。例如,要查找 template
的部分已定义,搜索:Ember.Handlebars.registerHelper('template'
{{模板}}
类似于{{partial}}
,但会查找您在 Ember.TEMPLATES
中定义的模板哈希。从源码中我们可以看到一个例子:Ember.TEMPLATES["my_cool_template"] = Ember.Handlebars.compile('<b>{{user}}</b>');
然后我们就可以这样渲染它。
我听到有人低声说{{template}}
是@deprecated,但我目前找不到在哪里找到该信息。然而,值得一提的是,我从未发现自己使用过这个。相反,我更喜欢{{partial}}
.
编辑:从
开始似乎不是 @deprecated 。我的错误!
3df5ddfd4f
{{部分}}
这与 {{render}}
不同方法是 controller
和view
是从调用它的上下文继承的。例如,如果您位于 UserRoute
,然后在用户模板中加载部分内容,然后是 UserView
和UserController
都将传递给您的部分,因此它们可以访问与其当前父部分完全相同的信息。
部分名称在定义时以下划线开头。例如,Profile
部分将有 data-template-name
的:data-template-name="_profile"
但会作为 {{partial "profile"}}
插入到您的 View 中.
{{导出}}
您可能会发现自己经常使用这个。它主要用于 outlet
的情况。根据用户交互频繁变化。通过转换到 ( this.transitionTo
/{{#linkTo}}
) 另一个页面,Ember 将 View 插入到 {{outlet}}
中并附上相关controller
和view
.
举个例子,如果您要转换到 /#/pets,那么默认情况下,Ember 将加载 PetsView
进入{{outlet}}
,并附上PetsController
,所有这一切都是在初始化PetsRoute
之后进行的。在初始化 View 和查找 Controller 之前接受指令。
{{渲染}}
这是 {{outlet}}
的混合物和一个 {{partial}}
。它用于不会切换到其他页面的静态页面(如 outlet
那样),但它不会继承 Controller 和 View (如 partial
那样)。
最好有例子。假设您有一个导航。通常您只有一个导航,并且不会因另一个导航而改变,但您希望导航有自己的 Controller 和 View ,而不是从上下文继承(可能是 ApplicationRoute
)。因此,当您插入导航( {{render "navigation"}}
)时,Ember 将附加 App.NavigationController
和App.NavigationView
.
摘要
template
:查询全局哈希并在找到它时插入 View (可能很快就会被@deprecated);partial
:用于分割复杂的 View ,并从父级继承 Controller / View (如果您位于 UserController
,则部分 View 也可以访问此 View 及其关联的 View )。outlet
:使用最广泛,允许您快速切换页面到其他页面。附有相关 Controller / View 。render
:与 socket 类似,但用于在整个应用程序中持久存在的页面。假定相关的 Controller / View ,并且不继承它们。我解释得清楚吗?
只是为了澄清:
关于ember.js - emberjs Handlebars 模板中的不同渲染技术,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14802223/
随着从 SproutCore 2.0 到 EmberJS 的迁移,有命名空间和 Github 存储库迁移。核心的东西好像移到了http://github.com/emberjs组织 Github 帐户
我有一条使用 ArrayController 来显示对象的路线。在执行某些操作后,使用 controller.clear() 和 controller.addObjects() 方法再次填充数组。我需
我有一个在 Ember 中创建的自定义 View 。我真的很喜欢 {{yield}} helper 让我控制三明治的“面包”。但是,我现在想要做的是创建一个“双层”三明治,并有一个超过 1 个产量的
过去 6 个月我正在开发一个 Emberjs 组件。 当我尝试开发表格组件时,我开始遇到第一个性能问题。此表中的每个单元格都是 Ember.View,并且每个单元格都绑定(bind)到对象属性。当表格
我有一个名为 docTemplateID 的变量/操作。docTemplateID 的值可以是 1 或 2单击按钮 1 设置 docTemplateID = 1。单击“提交”按钮将使用新值创建 doc
我正在尝试编写一个小 Action 来搜索数据存储,顺便说一下,数据存储中已经加载了数据。我希望能够通过字符串(即名字)进行搜索。 这是我到目前为止的代码示例。 this.get() 正在从搜索表单中
我正在尝试在注册表单上创建提交操作。这是我的寄存器 handle : {{input class="form-control" value=username type="text" pl
我有一个我认为相当正常的 JSON 响应: "data": { ..... "user": { "name": "John", "surname": "Doe" } .
如何定义仅在按下特定修饰键时调用的操作(单击时)? allowedKeys当没有按下修饰键时也会执行该操作。 最佳答案 一种方法就是做 my item 在你的 Controller /父组件中
所以,这基本上就是我想要的。但我需要获取可以在 ember 检查器中看到的当前路径,但如何在组件中获取它?或者有更好的方法来做到这一点吗?也许是一项服务? import Ember from 'emb
我只是想循环遍历我生成的一些虚拟数据,这样我就可以设置网站的样式,我的路由器中有这个: import Ember from 'ember'; export default Ember.Route.ex
这就是我所拥有的。 2 种模型:“注释”和“用户”。注释有一个名为“用户”的字段,它使“1 个用户对应多个注释”进行复制。数据取自 Mirage。 备注型号: export default DS.Mo
我尝试复制搜索字段,就像它们在 emberjs.com 处显示的那样。但是由于某种原因,当输入查询并按 Enter 或单击提交按钮时,我的代码不断产生以下错误(在 google chrome 中):
我正在测试过滤器内容,仅显示 X 个结果,我必须使用计数器来执行此操作,因为适配器如何返回数据。 http://jsfiddle.net/eAvET/ 当您加载此修改后的示例时,显示 0 数据,但是当
我的应用程序有一个名为 Balance 的模型,我们可以在其中添加金额和说明。我创建了一个操作,当您单击按钮时添加一些余额记录,到目前为止效果很好。问题是我创建了一个名为“totalBalance”的
我正在使用 ember 的查询参数按布局类型过滤结果列表。我想检查指定的查询是否在 availableLayouts 中。我知道我可以检查该值是否在此数组中,但我不确定 ember 在什么时候设置“布
我有一段数据(对象),它从服务器端脚本打印为全局变量。 user = { id : 1, name: 'foo', avatar : 'http://foo.com/avatar.jpg'} 整个应用
我正在使用 Ember 构建一个单页音乐网络应用程序。每个轨道在页面上都表示为一个组件。给定页面上有许多轨道。当用户单击播放时,组件会更新其 UI 以反射(reflect)这一点,并且主路由会跟踪当前
我想将社交分享按钮(fb、twitter、vk)添加到我的 Ember 应用程序中。我找到了一些库并集成了它们,但它们有一个重要的限制。社交网络使用其机器人抓取共享页面,并从页面中检索特定的元属性。但
我试图用easyForm预选一个选择框。 https://github.com/dockyard/ember-easyForm 我做了一个JsBin:http://emberjs.jsbin.com/
我是一名优秀的程序员,十分优秀!