1 つのページに複数のモジュールを追加して、Web ページが必要なときにのみこのモジュールを読み込むようにすることができます。モジュールの切り替えは、Web ページの切り替えをほぼ置き換えることができるため、この切り替えはオンデマンドでロードされることで実現できます。
一見するとごく普通のことのように思えますが、よく考えてみると、このアイデアは多くのリソースを解決できることがわかります。
例えば、1,000個の商品の情報を表示する必要があるページがあり、それぞれの商品の表現形式が異なる場合(それぞれ独立したCSSやJSがあると仮定します)、一般的には1,000個のWebを用意する必要があります。この情報をロードするページ。ただし、このモジュール式のアイデアを使用すると、バックグラウンドで 1,000 の異なるモジュールを設定し、必要に応じて必要な製品の対応するモジュールを 1 つのページにロードすることができます。
上記で紹介した機能を実現するには、ルーティング機能を使用する必要があります。
主なアイデア:
1. バックグラウンドで複数の独立したモジュールをセットアップします
2. ルーティングを通じて必要なモジュールを抽出し、必要に応じてホームページにロードします
4.他のモジュールをロードする モジュールは非表示になります。
では、ルーティングモジュールを確立するにはどれくらいの労力がかかるでしょうか?実際、これは驚くほど簡単です:
まず、メイン ページに対応するコードを記述します:
<html ng-app="myTodo"><head> <meta charset="utf-8"> <title>angularjs • TodoMVC</title> <link rel="stylesheet" href="node_modules/todomvc-common/base.css"> <link rel="stylesheet" href="node_modules/todomvc-app-css/index.css"> <style> .pagination { overflow: hidden; padding: 20px; } .pagination ul li { width: 60px; height: 30px; line-height: 30px; border:1px solid black; float: left; list-style-type: none; margin-right: 10px; text-align: center; } </style> </head> <body> <ng-view></ng-view> <!-- 路由区域,视图区域--> <footer id="info"> <p>Double-click to edit a todo</p> <p>Created by <a href="http://sindresorhus.com">Sindre Sorhus</a></p> <p>Part of <a href="http://todomvc.com">TodoMVC</a></p> </footer> <script src="node_modules/angular/angular.js"></script> <script src="node_modules/angular-route/angular-route.js"></script> <script src="js/app.js"></script> </body> </html>
他のものはすべて装飾です。24 行目を見てください。
ルーティングエリアとビューエリアでは、コンテンツを追加したり、Web ページを追加したりすることもできます。
次に、対応するapp.jsを見てください。
var app = angular.module("myTodo", ['ngRoute']); //路由的配置: app.config(function($routeProvider) { var routeconfig = { templateUrl: "body.html", controller: "myTodoCtrl" /*controller: 'myTodoCtrl'*/ } var ohter_config = { templateUrl: "other.html" } $routeProvider. when("",routeconfig). //status : 它对应我们页面的hash: all completed active //路由规则的优先级按写法的顺序所决定的 when("/other", ohter_config). when("/:aaa", routeconfig ). otherwise( { redirectTo: "/all" }); }); app.controller("myTodoCtrl", function($scope, $routeParams, $filter){ console.log($routeParams); });
ルーティングのみを使用する場合は、上記のコードで十分です。
1. ページがホームページまたはその他の奇妙な場所に留まると、URL は - http://127.0.0.1:8020/finishAngularJS-mark2/index に自動的にジャンプします。 .html#/all
インデックスの後にあるものに注意してください。 2. ページジャンプ方向が/otherの場合、
http://127.0.0.1:8020/finishAngularJS-mark2/iother.htmlにジャンプします
の下でのジャンプです。
http://127.0.0.1:8020/finishAngularJS-mark2/index.html#/all
var routeconfig = { templateUrl: "body.html", controller: "myTodoCtrl" /*controller: 'myTodoCtrl'*/ } var ohter_config = { templateUrl: "other.html" }
$routeProvider. when("",routeconfig). //status : 它对应我们页面的hash: all completed active //路由规则的优先级按写法的顺序所决定的 when("/other", ohter_config). when("/:aaa", routeconfig ). otherwise( { redirectTo: "/all" }); });