入门指南 获取Ember 概念 对象模型 应用 模板 路由 组件 控制器 模型 视图 枚举 测式 配置Ember.js COOKBOOK 理解Ember.js

发布于 2015-08-18 16:41:29 | 627 次阅读 | 评论: 0 | 来源: 网络整理

默认情况下,路由通过浏览器的哈希来加载应用程序的起始状态,并且你在程序里点来点去的时候也是通过哈希来保持同步的。 目前,这依赖于浏览器中的hashchange事件。

下面的这个路由会将你从/#/posts/new 带到 posts.new 路由中去。

 
1
2
3
4
5
App.Router.map(function() {
  this.resource('posts', function() {
    this.route('new');
  });
});
 

如果你想/posts/new 这样的地址起作用,你可以用浏览器的history API来知会路由器。

需要注意服务器必须能接收Ember应用定义的所有路由。

 
1
2
3
App.Router.reopen({
  location: 'history'
});
 

最终,如果你一点儿都不想浏览器的URL地址与你的应用程序交互,你可以彻底地禁用掉地址API。这在测试环境里很适用,或者你想用路由来管理状态,但是暂时又不想路由把URL搞乱掉(比如你将你的程序嵌入到一个大的网页里的时候)。

 
1
2
3
App.Router.reopen({
  location: 'none'
});
 
最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务