Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

AngularJS 1.1.5 - automatically adding hash tag to URLs

Does anyone know why version 1.1.5 automatically adds a hashtag to your urls, and how to turn this off? IMO this is ugly looking. It happens whenever you have a url that doesn't end in a forward slash. (I'm not using routes or anything like that).

So this:

http://my.website.com/about

becomes

http://my.website.com/about#/about

and this:

http://my.website.com/about.html

becomes:

http://my.website.com/about.html#/about.html

but this:

http://my.website.com/about/

doesn't have this problem.

like image 750
Kevin Beal Avatar asked Jun 27 '13 18:06

Kevin Beal


3 Answers

I experienced this issue just the other day. I solved it by enabling HTML5 mode for $locationProvider. See Docs for $location - HTML5 Mode Updated link for $location - HTML5 Mode.

It should look similar to this:

.config(['$locationProvider', function($locationProvider){
    $locationProvider.html5Mode(true).hashPrefix('!');
}]);
like image 86
EnigmaRM Avatar answered Nov 14 '22 02:11

EnigmaRM


This seems to be a bug introduced in angularjs 1.1.5 (since 1.1.4 does not exhibit this problem). I have reported the bug here:

https://github.com/angular/angular.js/issues/3083

like image 45
jssebastian Avatar answered Nov 14 '22 03:11

jssebastian


In $routeProvider set HTML5 mode as true as following

$locationProvider.html5Mode(true);

And in head section of your page add this following line

<base href="/">
like image 1
vijay Avatar answered Nov 14 '22 03:11

vijay