$ Il servizio di localizzazione risponde per l'analisi dell'URL nella barra degli indirizzi del browser e rende l'URL disponibile per l'APP.
Poiché si utilizzano segmenti di ricerca e percorso URL standard, è necessario impostare $ locationProvider html5Mode su true.
$ locationProvider utilizzerà hashbang come modalità predefinita.
Se non si imposta html5Mode su true, si otterrà una stringa vuota quando si tenta di recuperare il percorso url.
Quindi utilizzare $ location service per recuperare il percorso dell'URL dopo aver impostato html5Mode.
E scrivi la tua regola per elaborare il percorso.
Si supponga che l'URL completo è: http://example.com/person/show/321
main.js
angular.module("MyAPP",[],function($locationProvider){
$locationProvider.html5Mode(true);
});
function MainController($location){
var pId = $location.path().split("/")[3]||"Unknown"; //path will be /person/show/321/, and array looks like: ["","person","show","321",""]
console.log(pId);
}
index.html
<!DOCTYPE html>
<html lang="en" ng-app="MyAPP">
<head>
<meta charset="utf-8">
<title>Angular test</title>
</head>
<body ng-controller="MainController">
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.0.6/angular.min.js"></script>
<script src="js/main.js"></script>
</body>
</html>
Spero che questo è utile per voi.
fonte
2014-12-08 06:25:49
Si sta utilizzando '$ routeProvider' in modalità HTML5 (nessun '#' accesso nell'URL) o no? – GregL
Non ho usato $ routeProvider, lo voglio per chiamare api da una chiamata Ajax. – Pravin
Cosa ottieni quando esegui 'console.dir ($ posizione)'? – GregL