Quantcast
Channel: AngularJS routing without the hash '#' - Stack Overflow
Viewing all articles
Browse latest Browse all 11

Answer by georgeawg for AngularJS routing without the hash '#'

$
0
0

Using HTML5 mode requires URL rewriting on server side, basically you have to rewrite all your links to entry point of your application (e.g. index.html). Requiring a <base> tag is also important for this case, as it allows AngularJS to differentiate between the part of the url that is the application base and the path that should be handled by the application. For more information, see AngularJS Developer Guide - Using $location HTML5 mode Server Side.


Update

How to: Configure your server to work with html5Mode1

When you have html5Mode enabled, the # character will no longer be used in your urls. The # symbol is useful because it requires no server side configuration. Without #, the url looks much nicer, but it also requires server side rewrites. Here are some examples:

Apache Rewrites

<VirtualHost *:80>    ServerName my-app    DocumentRoot /path/to/app<Directory /path/to/app>        RewriteEngine on        # Don't rewrite files or directories        RewriteCond %{REQUEST_FILENAME} -f [OR]        RewriteCond %{REQUEST_FILENAME} -d        RewriteRule ^ - [L]        # Rewrite everything else to index.html to allow html5 state links        RewriteRule ^ index.html [L]</Directory></VirtualHost>

Nginx Rewrites

server {    server_name my-app;    index index.html;    root /path/to/app;    location / {        try_files $uri $uri/ /index.html;    }}

Azure IIS Rewrites

<system.webServer><rewrite><rules> <rule name="Main Rule" stopProcessing="true"><match url=".*" /><conditions logicalGrouping="MatchAll"><add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" /><add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" /></conditions><action type="Rewrite" url="/" /></rule></rules></rewrite></system.webServer>

Express Rewrites

var express = require('express');var app = express();app.use('/js', express.static(__dirname +'/js'));app.use('/dist', express.static(__dirname +'/../dist'));app.use('/css', express.static(__dirname +'/css'));app.use('/partials', express.static(__dirname +'/partials'));app.all('/*', function(req, res, next) {    // Just send the index.html for other files to support HTML5Mode    res.sendFile('index.html', { root: __dirname });});app.listen(3006); //the port you want to use

See also


Viewing all articles
Browse latest Browse all 11

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>