欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解AngularJS1.6版本中ui-router路由中/#!/的解決方法

 更新時間:2017年05月22日 10:16:41   作者:justforuse  
本篇文章主要介紹了詳解AngularJS1.6版本中ui-router路由中/#!/的解決方法,非常具有實用價值,需要的朋友可以參考下

AngularJS 路由 是通過 # + 標記 幫助我們區(qū)分不同的邏輯頁面并將不同的頁面綁定到對應的控制器上。因此在設置好路由規(guī)則后,為html頁面的a標簽設置href路由鏈接切換不同的視圖。Angular1.6版本之前通常有href=“#...”或href=“#/...”這兩種寫法,結果這兩種寫法在Angular1.6中沒有任何反應。

結果查看了下瀏覽器地址欄,默認視圖鏈接竟然顯示“#!/..”,是的,中間多加了個!號。

AngularJS升級到了1.6版本后,里面多了很多/#!/的改動。那么1.6究竟做了哪些改變呢?可以參考這個:https://github.com/angular/angular.js/commit/aa077e81129c740041438688dff2e8d20c3d7b52

解決方案一:

所以在html頁面a標簽上將href的屬性值添加一個!號就可以了。

<p><a href="#!/addStudent" rel="external nofollow" rel="external nofollow" >添加學生</a></p> 
<p><a href="#!/viewStudents" rel="external nofollow" rel="external nofollow" >查看學生</a></p> 

完整代碼:

<html> 
  <head> 
    <meta charset="utf-8" /> 
    <title>AngularJS 視圖</title> 
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.1/angular.min.js"></script> 
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.1/angular-route.min.js"></script> 
  </head> 
  <body> 
    <h2>AngularJS 視圖</h2> 
    <div ng-app="mainApp"> 
      <p><a href="#!/addStudent" rel="external nofollow" rel="external nofollow" >添加學生</a></p> 
      <p><a href="#!/viewStudents" rel="external nofollow" rel="external nofollow" >查看學生</a></p> 
      <div ng-view></div> 
      <script type="text/ng-template" id="addStudent.html"> 
        <h2>添加學生</h2> 
        {{message}} 
      </script> 
      <script type="text/ng-template" id="viewStudents.html"> 
        <h2>查看學生</h2> 
        {{message}} 
      </script> 
    </div> 
    <script> 
      var mainApp=angular.module("mainApp",['ngRoute']); 
      mainApp.config(["$routeProvider",function($routeProvider){ 
        $routeProvider.when('/addStudent',{ 
          templateUrl:'addStudent.html', 
          controller:'AddStudentController' 
        }).when('/viewStudents',{ 
          templateUrl:'viewStudents.html', 
          controller:'ViewStudentsController' 
        }).otherwise({ 
          redirectTo:'/addStudent' 
        }); 
      }]); 
      mainApp.controller("AddStudentController",function($scope){ 
        $scope.message="這個頁面是用于顯示學生信息的輸入表單"; 
      }); 
      mainApp.controller("ViewStudentsController",function($scope){ 
        $scope.message="這個頁面是用于顯示所有學生信息"; 
      }); 
    </script> 
  </body> 
</html> 

解決方案二:

如果想讓路由依舊表現的與之前版本的一致可以這樣做:

mainApp.config(["$locationProvider","$routeProvider",function($locationProvider,$routeProvider){ 
    $locationProvider.hashPrefix(''); 
}]); 
<p><a href="#addStudent" rel="external nofollow" rel="external nofollow" >添加學生</a></p> 
<p><a href="#viewStudents" rel="external nofollow" rel="external nofollow" >查看學生</a></p> 

完整代碼:

<html> 
  <head> 
    <meta charset="utf-8" /> 
    <title>AngularJS 視圖</title> 
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.1/angular.min.js"></script> 
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.1/angular-route.min.js"></script> 
  </head> 
  <body> 
    <h2>AngularJS 視圖</h2> 
    <div ng-app="mainApp"> 
      <p><a href="#addStudent" rel="external nofollow" rel="external nofollow" >添加學生</a></p> 
      <p><a href="#viewStudents" rel="external nofollow" rel="external nofollow" >查看學生</a></p> 
      <div ng-view></div> 
      <script type="text/ng-template" id="addStudent.html"> 
        <h2>添加學生</h2> 
        {{message}} 
      </script> 
      <script type="text/ng-template" id="viewStudents.html"> 
        <h2>查看學生</h2> 
        {{message}} 
      </script> 
    </div> 
    <script> 
      var mainApp=angular.module("mainApp",['ngRoute']); 
      mainApp.config(["$locationProvider","$routeProvider",function($locationProvider,$routeProvider){ 
        $locationProvider.hashPrefix(''); 
        $routeProvider.when('/addStudent',{ 
          templateUrl:'addStudent.html', 
          controller:'AddStudentController' 
        }).when('/viewStudents',{ 
          templateUrl:'viewStudents.html', 
          controller:'ViewStudentsController' 
        }).otherwise({ 
          redirectTo:'/addStudent' 
        }); 
      }]); 
      mainApp.controller("AddStudentController",function($scope){ 
        $scope.message="這個頁面是用于顯示學生信息的輸入表單"; 
      }); 
      mainApp.controller("ViewStudentsController",function($scope){ 
        $scope.message="這個頁面是用于顯示所有學生信息"; 
      }); 
    </script> 
  </body> 
</html> 


這樣瀏覽器訪問時,就不會多出個!號了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

最新評論