英文原文:http://emberjs.com/guides/routing/specifying-the-location-api/

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

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

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

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

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

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

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

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