AngularJs Routing without hashtag in link?

时光毁灭记忆、已成空白 提交于 2019-12-20 06:24:36

问题


I've recently began learning AngularJs for web development and am loving it so far. However, I'm not so sure about having hashtags withing the link when routing between views. My main concern is how Google will cache the pages on the site and whether the links will work both ways, i.e. whether users can just click www.sampledomain.com/#/orders/450 and be directed straight to the order page. Is this an okay method or is there a way to route views without the hashtag?

When I remove the hashtag, the reload the page and gets 404 error. Can anyone give me a decent explanation of what is going on. Thanks


回答1:


When I remove the hashtag, the reload the page and gets 404 error

That's because in your server side code you are probably not handling a request like "www.sampledomain.com/orders/450"

You can have your server-side code handle this request by either returning a redirect to the new URL ("www.sampledomain.com/#/orders/450") or just return the correct HTML directly. The "right" solution will depend on your needs.




回答2:


  1. User can just click link with a hashtag and it will be directed straight to the order page.

  2. Google treats links with hashtags as different URL's when the content is different. It's more about SEO then angular.js, but here is an article about that: The First Link Counts Rule and the Hash Sign - Does it Change PR Sculpting?




回答3:


You might want to set Angular's $locationProvider to use html5Mode.

FTA: $location service has two configuration modes which control the format of the URL in the browser address bar: Hashbang mode (the default) and the HTML5 mode which is based on using the HTML5 History API. Applications use the same API in both modes and the $location service will work with appropriate URL segments and browser APIs to facilitate the browser URL change and history management.

html5Mode will give you "normal" urls in modern browsers while falling back to hash bangs on older browsers.

An html5Mode url:

http://foo.com/bar?baz=23#baz

a hashbang url:

http://foo.com/#!/bar?baz=23#baz


来源:https://stackoverflow.com/questions/20335251/angularjs-routing-without-hashtag-in-link

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!