首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ember.js绑定传播顺序

ember.js绑定传播顺序
EN

Stack Overflow用户
提问于 2012-04-20 04:17:07
回答 2查看 320关注 0票数 0

我知道Ember.js会推迟绑定更改。我想知道当Ember.js通知绑定更改时,它是否保持任何顺序?

这里有一个非常做作的例子:

代码语言:javascript
复制
{{#if App.backVisible}}
    <img {{bindAttr src=App.selectedPerson.avatar}} />
{{else}}
    name: {{App.selectedPerson.fullName}}
{{/if}}

然后在其他地方我做了:

代码语言:javascript
复制
App.set("selectedPerson", someOtherPerson)
App.set("backVisible", true)

是否可以保证在backVisible属性更改之前填充src绑定?

EN

回答 2

Stack Overflow用户

发布于 2012-04-20 04:39:52

能保证在backVisible属性更改之前填充src绑定吗?

我真的不明白为什么你要在设置backVisible属性之前设置Ember 。从你设计的例子来看,这两个属性在功能上似乎是非常独立的。

但是,如果您仍然希望强制在视图中填充src绑定,则始终可以强制呈现。在Ember中,渲染是通过run循环延迟的。您可以通过调用Ember.run.end()使运行循环立即执行

有关run循环的更多信息,请尝试此链接:http://blog.sproutcore.com/the-run-loop-part-1/

这篇博文来自Sproutcore时代,但核心概念在Emberjs中仍然是一样的。

票数 0
EN

Stack Overflow用户

发布于 2012-12-10 07:57:17

您寻找的答案是Ember yes(因为它首先更新所有Ember对象,然后更新UI)。

然而,我相信你的应用程序在没有这个保证的情况下仍然可以很好地工作,也就是说,因为你使用了Ember的绑定,即使App.backVisible会首先更新,我甚至指的是生成的UI ( img-tag ),img-tag仍然很好,即使它的src属性设置为"“(没有"NPE",即使你绑定它a.b.cd和b为空)。

几毫秒后,Ember将更新src属性以包含更新的值,图像将被加载并显示。

我认为这是Ember的强项之一:状态在一个地方,一切都反映在它身上。如果绑定导致暂时没有任何地方(尽管通常不会发生这种情况),一切仍然有效。

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

https://stackoverflow.com/questions/10236061

复制
相关文章

相似问题

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