URLは
person/show/31586
また
person/show/31586#tab1
IDをAngularで取得することは可能ですか? ルーティングは angular によって管理されません。上記の URL はページをロードし、ページ上の一部のコンテンツのみが angular によって管理されます。
URLは
person/show/31586
また
person/show/31586#tab1
IDをAngularで取得することは可能ですか? ルーティングは angular によって管理されません。上記の URL はページをロードし、ページ上の一部のコンテンツのみが angular によって管理されます。
この$location
サービスは、ブラウザーのアドレス バーから URL を解析し、その URL をアプリで使用できるようにします。通常の URL パスと検索セグメントを使用しているため、 でhtml5Mode
true に設定する必要があります$locationProvider
。
デフォルトで$locationProvider
は、hashbangs を使用するため、html5Mode
true に設定しないと、URL パスをフェッチしようとすると空の文字列が返されます。
を設定html5mode
したら、サービスを使用し$location
て URL パスを取得し、独自のルールを記述してパスを処理できます。
たとえば、完全な URL が次のようになっているとします。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>
これがお役に立てば幸いです。
他の誰かが Angular での URL の取得に関連するヘルプを求めてここに到着した場合に備えて。時折、以下にアクセスする必要があるかもしれませんabsUrl
:
console.log($location.absUrl());
http://127.0.0.1:3000/home