当前位置: 首页 > 文档资料 > EmberJS 入门教程 >

多个细分(Multiple Segments)

优质
小牛编辑
130浏览
2023-12-01

对于多个段,如果路由是嵌套的,则可以为每个段提供模型或标识符。

语法 (Syntax)

Router.map(function() {
   this.resource('route_name');
   this.resource('route_name', { path: 'route_path' });
});

例子 (Example)

该示例通过为段提供标识符来显示在嵌套路由中使用多个段。 创建两个名称为inforecord路由,并打开router.js文件以定义URL映射 -

import Ember from 'ember';
import config from './config/environment';
const Router = Ember.Router.extend ({
   location: config.locationType,
   rootURL: config.rootURL
});
Router.map(function() {
   this.route('info');
   this.route('record', { path: 'records/:records_id' });
});
export default Router;

使用以下代码打开在app/templates/下创建的application.hbs文件 -

{{#link-to 'info'}}Fruits{{/link-to}}
{{#link-to 'record' recoModel}}Some Record{{/link-to}}
{{outlet}}

单击“Fruits”链接时,页面应打开info.hbs文件,其中包含以下代码 -

<p>Some Fruits</p>
<ul>
   <li>Orange</li>
   <li>Banana</li>
</ul>
{{outlet}}

如果单击Some Record link ,页面应打开record.hbs文件,其中包含以下代码 -

<p>Some Records</p>
{{model.name}}
{{outlet}}

现在创建控制器application.js ,它将在app/controller/下创建,具有以下代码 -

import Ember from 'ember';
export default Ember.Controller.extend ({
   recoModel: function(){
      //return the records value to the called route
      return {records_id:1, name:'Docs List'};
   }.property()
});

输出 (Output)

运行ember服务器; 你会收到以下输出 -

Ember.js模板内联助手

当您单击Fruits链接时,它将显示模板文件中的以下文本 -

Ember.js模板内联助手

当您单击Some Record链接时,它将显示模板文件中的以下文本 -

Ember.js模板内联助手