我有以下代码生成链接到对象,我有一个模板,呈现它,但我想有列表中的每个项目调用不同的模板或显示不同的项目。这可能吗?
<div class="main-content container">
<div class="container-fluid">
<div class="col-xs-3">
<div class="span3">
<table class='table'>
<thead>
<tr><th><h3>Select Your Source</h3></th></tr>
{{#each refRecord in model}}
<tr><td>
{{#link-to 'ref' refRecord classNames="fullwidth"}}{{refRecord.type}}{{/link-to}}
</td></tr>
{{/each}}
</table>
</div>
</div>
<div class="col-xs-9">
{{outlet}}
</div>
</div>
</div>
我不确定我是否理解正确,但我以两种方式回答了你的问题,要么链接到不同的模板,要么在列表中呈现每个项目不同。
链接到不同的模板
可以在link-to语句中使用属性而不是字符串来创建动态链接。
<ul>
{{#each item in model}}
<li>{{#link-to item.template item}}{{item.color}}{{/link-to}}</li>
{{/each}}
</ul>
http://emberjs.jsbin.com/xarixiyu/1/edit 呈现每个项目不同
这有点不同,因为render
不允许获取属性并动态解析名称。但是你仍然可以使用if语句,以不同的方式呈现不同的项。
{{#each item in model}}
<li>
{{#if item.foo}}
{{render 'foo' item}}
{{/if}}
{{#if item.bar}}
{{render 'bar' item}}
{{/if}}
</li>
{{/each}}
http://emberjs.jsbin.com/xarixiyu/2/edit