简体   繁体   English

如何将模型路由名称项传递给ember.js模板中的linkTo

[英]How to pass Model route name item to linkTo in template in ember.js

How do I pass a route name to a {{linkTo}} dynamically? 如何动态将路由名称传递给{{linkTo}}?

For example, given this code: 例如,给出以下代码:

App.Router.map(function() {
 this.resource('anon', {path: '/main'},
 function() {
   this.route('home', {path:'/home'});
   this.route('about', { path: '/about' });
   this.route('contact', { path: '/contact' });
 });
});

App.NavController = Ember.ArrayController.extend({
  selectedNav:'',
  setNav:function(value){
  var nav = App.Nav.find(value);
  var items = nav.get('navItems');
  this.set('content', items);    
  }
});

these templates: 这些模板:

<script type="text/x-handlebars" data-template-name="nav">
  <ul class="nav">
    {{#each in controller}}
      {{ partial "basicNav"}}
    {{/each}}
   </ul>
</script>

<script type="text/x-handlebars" data-template-name="_basicNav">
  <li>{{#linkTo navItemPath}}{{navItemName}}{{/linkTo}}</li>
</script>

and these models with the following fixture data: 这些模型具有以下夹具数据:

App.Nav = DS.Model.extend({
  navItems:DS.hasMany('App.NavItem'),
  name:DS.attr('string')
});

App.NavItem = DS.Model.extend({
  nav:DS.belongsTo('App.Nav'),
  navItemName:DS.attr('string'),
  navItemPath:DS.attr('string')
});

App.Nav.FIXTURES = [
 {
  id: 10,
  name: 'Anon',
  navItems: [100,200,300]
 }
];

App.NavItem.FIXTURES = [
{
  id:100,
  nav:10,
  navItemName:'Home',
  navItemPath:'anon.home'
},
{
  id:200,
  nav:10,
  navItemName:'Contact',
  navItemPath:'anon.contact'
},
{
  id:300,
  nav:10,
  navItemName:'About',
  navItemPath:'anon.about'
}
];

How do I pass navItemPath to the {{linkTo}} helper? 如何将navItemPath传递给{{linkTo}}助手? In this code snippet: 在此代码段中:

{{#linkTo navItemPath}}{{navItemName}}{{/linkTo}}

ember complains that it can't find the "navItemPath" route, like it's looking for it literally. ember抱怨说它找不到字面的“ navItemPath”路由。 If I replace that with a valid literal route like: 如果我将其替换为有效的文字路径,例如:

{{#linkTo 'anon.home'}}{{navItemName}}{{/linkTo}}

ember will render the linkTo with the navItemName as expected, so I know the controller is passing it the right data, but of course all the routes are goofy. ember将按预期方式用navItemName呈现linkTo,因此我知道控制器正在向其传递正确的数据,但是当然所有路由都是愚蠢的。 Am I missing something obvious? 我是否缺少明显的东西?

You can't do that with LinkTo helper, you need to bind the href of your link to navItemPath using bindAttr 你不能做到这一点与LinkTo帮手,您需要在链接的href绑定到navItemPath使用bindAttr

<a {{bindAttr href="navItemPath"}}>{{navItemName}}</a>

Make sure the the logic rending navItemPath's value takes into account the location API 确保逻辑导出navItemPath的值考虑了位置 API

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM