我只想从ngRoute
切换到ui.router
。
我从Spring Security and Angular JS获取基本源代码 (OAuth2 Auth服务器,OAuth2用户界面,OAuth2资源)
为OAuth2 UI添加了依赖关系
<dependency>
<groupId>org.webjars</groupId>
<artifactId>angular-ui-router</artifactId>
<version>0.2.18</version>
</dependency>
和<js>webjar:angular-ui-router/0.2.18/angular-ui-router.js</js>
到wro.xml
并删除了<js>webjar:angularjs/1.4.9/angular-route.js</js>
我将hello.js
更改为
var hello = angular.module('hello', ['ui.router']);
hello.config(function($stateProvider, $urlRouterProvider, $httpProvider) {
$urlRouterProvider.otherwise('/home');
$stateProvider
// HOME STATES AND NESTED VIEWS ========================================
.state('home', {
url: '/home',
templateUrl: 'home.html',
controller: 'home'
})
// ABOUT PAGE AND MULTIPLE NAMED VIEWS =================================
.state('about', {
// we'll get to this in a bit
});
$httpProvider.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest';
$httpProvider.defaults.headers.common['Accept'] = 'application/json';
});
hello.controller('navigation',
function($rootScope, $http, $location, $state) {
var self = this;
self.tab = function(route) {
return $state.params && route === $state.params.controller;
};
$http.get('user').then(function(response) {
if (response.data.name) {
$rootScope.authenticated = true;
} else {
$rootScope.authenticated = false;
}
}, function() {
$rootScope.authenticated = false;
});
self.credentials = {};
self.logout = function() {
$http.post('logout', {}).finally(function() {
$rootScope.authenticated = false;
$location.path("/");
});
}
});
hello.controller('home', function($http) {
var self = this;
$http.get('resource/').then(function(response) {
self.greeting = response.data;
});
});
index.html
到
<html>
<head>
<title>Hello AngularJS</title>
<link href="css/angular-bootstrap.css" rel="stylesheet">
<style>
.navbar {
border-radius: 0;
}
</style>
</head>
<body ng-app="hello">
<!-- NAVIGATION -->
<nav class="navbar navbar-inverse" role="navigation">
<div class="navbar-header">
<a class="navbar-brand" data-ui-sref="home">AngularUI Router</a>
</div>
<div ng-controller="navigation as nav" class="container">
<ul class="nav navbar-nav">
<li><a data-ui-sref="home">Home</a></li>
<li><a data-ui-sref="about">About</a></li>
<li><a href="login">login</a></li>
</ul>
</div>
</nav>
<!-- MAIN CONTENT -->
<div class="container">
<!-- THIS IS WHERE WE WILL INJECT OUR CONTENT ============================== -->
<div data-ui-view></div>
</div>
<script src="js/angular-bootstrap.js" type="text/javascript"></script>
<script src="js/hello.js"></script>
</body>
</html>
如何在
处显示数据home.html的
<h1>Greeting</h1>
<div ng-show="authenticated">
<p>The ID is {{controller.greeting.id}}</p>
<p>The content is {{controller.greeting.content}}</p>
</div>
<div ng-show="!authenticated">
<p>Login to see your greeting</p>
</div>
如果我访问http://localhost:9000/resource
我有类似的东西
{
"id": "81e5fa45-67f8-41a2-b373-26b100bfd997",
"content": "Hello World"
}
但未显示。
答案 0 :(得分:1)
在home.html
中,您的模板就像{{controller.greeting.id}}
,但有角度的内容并不知道controller
的含义。
所以,家庭的状态需要像这样修改:
.state('home', {
url: '/home',
templateUrl: 'home.html',
controller: 'home',
controllerAs: 'controller'
})
然后模板将知道controller
所指的内容。