Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Angular - Unhandled Navigation Error after building

I have built a simple angular app with 2 routes through the following command:

ng build --aot --prod --base-href ./

Then i open the index.html file located in the dist folder and the app runs but the the routes don't work and i get the following warning on console:

enter image description here

Hope to have explained my question well. Thanks in advance.

like image 235
Elkin Avatar asked Dec 18 '18 12:12

Elkin


3 Answers

Angular routing works if you use hash routing and define your base href as follows in your index.html.

<base href="#">
like image 94
chenson42 Avatar answered Nov 12 '22 21:11

chenson42


Using Angular routing engine will force you to host your app in some server (e.g. IIS, NodeJS etc.)

A simple angular app without routes can run without hosting it on a server.

From Angular docs:

Angular apps are perfect candidates for serving with a simple static HTML server. You don't need a server-side engine to dynamically compose application pages because Angular does that on the client-side.

If the app uses the Angular router, you must configure the server to return the application's host page (index.html) when asked for a file that it does not have.

like image 40
benshabatnoam Avatar answered Nov 12 '22 19:11

benshabatnoam


In my case I would get:

Unhandled Navigation Error: main.af3eff424835a3d5642f.js:1

Because my base url was set to https://

<base href="https://example.com" />

But I was loading the site over http://

http://example.com

Solution was to either use the https:// url OR change the base url to allow access via http.

like image 4
Kim T Avatar answered Nov 12 '22 19:11

Kim T