没有显示的数据从ngRoute转换为UI.Router

时间:2016-12-17 15:10:57

标签: angularjs spring-boot oauth2

我只想从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"
}

但未显示。

1 个答案:

答案 0 :(得分:1)

home.html中,您的模板就像{{controller.greeting.id}},但有角度的内容并不知道controller的含义。

所以,家庭的状态需要像这样修改:

.state('home', {
  url: '/home',
  templateUrl: 'home.html',
  controller: 'home',
  controllerAs: 'controller'
})

然后模板将知道controller所指的内容。