Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

IE 9 not supporting $locationProvider.html5Mode

Hi I am creating an angularjs app . I made $locationProvider.html5Mode as true. Now I am getting pretty url without # . It is working fine in chrome and firefox. But when I tried to open it in IE 9 , it is reloading continuously.

like image 666
Sarath Pv Avatar asked Mar 31 '14 14:03

Sarath Pv


2 Answers

Bad news. IE9 do not support HTML5 History API. That is what angular html5Mode uses. If you need your app to run on IE9 you need to switch back or add code to detect if History API is available the use is or default to the hash

function supports_history_api() {
  return !!(window.history && history.pushState);
}

I know. Stupid IE. It should die a painful dead.

like image 151
Jorge Enrique Reyes Salas Avatar answered Oct 21 '22 16:10

Jorge Enrique Reyes Salas


$location Documentation

See "Hashband and HTML5 modes"

Basically, html5 mode uses History API when the browser supports it, and falls back to hashbang(#) when it is not supported.

You cannot "just" remove "#" in a browser without History API. Because when you change the url, the browser would then try to force a reload, breaking the flow.

like image 29
Gilles Bodart Avatar answered Oct 21 '22 17:10

Gilles Bodart