Angular.js之Router学习笔记
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>angularRouter</title>
</head>
<body>
<!--1:-->
<div ng-app="mymodule">
<!--通过ui-view属性指定路由模板的填充地点-->
<div ui-view></div>
</div>
<!--2:-->
<div ng-app="mymodule2">
<a href="" ui-sref="main">The first page </a>
<a href="#/list">The page of list </a>
</div>
<!--3:-->
<div ng-app="mymodule3">
<div ui-sref="index">The first page</div>
<div ui-sref="list">The page of list</div>
<div ui-view></div>
</div>
<!--4:-->
<div ng-app="mymodule4" ng-controller="ctrl4">
<a href="" ui-sref="main">The first page </a>
<a href="#/list">The page of list </a>
<div ui-view></div>
</div>
<!--5:-->
<div ng-app="mymodule5" ng-controller="ctrl5">
<a href="" ui-sref="main">The first page </a>
<a href="" ui-sref='list'>The page of list </a>
<div ui-view></div>
</div>
<!--6:-->
<div ng-app="mymodule6" ng-controller="ctrl6">
<a href="" ui-sref="main">The first page </a>
<a href="" ui-sref='list'>The page of list </a>
<div ui-view></div>
</div>
<script src="http://cdn.bootcss.com/angular-ui-router/0.4.2/angular-ui-router.js"></script>
<script src="http://cdn.bootcss.com/angular.js/1.4.6/angular.js"></script>
<script type="text/javascript">
/*Angular.js之Router:
1:uiRouter默认路由规则操作;路由一定是在控制器之上定义!a:继承ui.router模块;b:配置路由规则,依赖注入:$stateProvider/$urlRouterProvider两个服务;c:指定ui-view位置,确定路由模板显示位置
2:uiRouter链接上实现路由跳转方式:a:在a链接的href中指定路由规则中定义的url地址。b:在ui-sref属性中指定路由规则中定义的规则名称
3:uiRouter路由模板设置方式
4:uiRouter路由控制器使用方式:可以在路由中定义控制器controller,也可以在外部定义好,将controller属性定义为外部控制器的名称即可。
5:uiRouter路由控制器或指令中执行路由跳转,借助$state服务的go方法,只需将要跳转的路由名称传入该方法即可
6:uiRouter路由参数设置和$stateParams服务的使用,获取路由地址中的参数值,需要借助$stateParams服务,步骤:->路由地址中指定接收的参数->模板URL地址生成时,传入参数值->通过$stateParams服务获取参数值
7:uiRouter路由定义高效的父子嵌套路由:两种方式:第一种给路由名称添加命名空间,第二种给路由添加parent属性;模板中也需要指定ui-view,用来显示子视图
8:uiRouter路由定义超灵活的嵌套路由:给每个ui-view设置一个名称,当发生跳转时,给所有的ui-view都指定显示的模板,
9:uirouter路由多个view下的父子级视图嵌套使用:@符号指向父级ui-view视图标签;son@main:指定的是main视图下的son子视图*/
/*1:uiRouter默认路由规则操作;路由一定是在控制器之上定义!a:继承ui.router模块;b:配置路由规则,依赖注入:$stateProvider/$urlRouterProvider两个服务;c:指定ui-view位置,确定路由模板显示位置*/
let mymodule=angular.module('mymodule',['ui.router']);
//配置路由规则
mymodule.config(['$stateProvider','$urlRouterProvider',function($state,$urlRouter){
//定义路由规则
$state.state('default',{
url:'',
template:'<h1>welcome to puDong store !</h1>'
});
$urlRouter.otherwise('');
}]);
/*2:uiRouter链接上实现路由跳转方式:a:在a链接的href中指定路由规则中定义的url地址。b:在ui-sref属性中指定路由规则中定义的规则名称*/
//继承ui.router
let mymodule2=angular.module('mymodule2',['ui.router']);
//配置路由规则
mymodule2.config(['$stateProvider','$urlRouterProvider',function($state,$urlRouter){
//定义路由规则
$state.state('default',{
url:'',
template:'<h1>welcome to puDong store !</h1>'
}).state('main',{
url:'/index',
template:'<h2>This is a main page !</h2>'
}).state('list',{
url:'/list',
template:'<h2>This is a page of list !</h2>'
});
$urlRouter.otherwise('');
}]);
/*3:uiRouter路由模板设置方式*/
var mymodule3=angular.module('module3',['ui.router']);
mymodule3.config(['$stateProvider','urlRouterProvider',function($state,$urlRouter){
$state.state('default',{
url:'',
template:'<h1>welcome to puDong store !</h1>'
}).state('index',{
url:'/index',
template:''
}).state('list',{
url:'/list',
template:'<h2>This is a page of list !</h2>'
});
$urlRouter.otherwise('');
}]);
/*4:uiRouter路由控制器使用方式:可以在路由中定义控制器controller,也可以在外部定义好,将controller属性定义为外部控制器的名称即可。*/
var mymodule4=angular.module('module4',['ui-router']);
mymodule4.config(['$stateProvider','urlRouterProvider',function($state,$urlRouter){
$state.state('default',{
url:'',
template:'<h1>welcome to puDong store !</h1>'
}).state('index',{
url:'/index',
templateUrl:'router4.html',
/*controller:['$scope',function($scope){
$scope.title='puDong store';
}]*/
controller:'ctrl4'
}).state('list',{
url:'/list',
template:'<h2>This is a page of list !</h2>'
});
$urlRouter.otherwise('');
}]);
mymodule4.controller('ctrl4',['$scope',function($scope){
$scope.title='puDong store';
}])
/*5:uiRouter路由控制器或指令中执行路由跳转,借助$state服务的go方法,只需将要跳转的路由名称传入该方法即可*/
var mymodule5=angular.module('module5',['ui-router']);
mymodule5.config(['$stateProvider','urlRouterProvider',function($state,$urlRouter){
$state.state('default',{
url:'',
template:'<h1>welcome to puDong store !</h1>'
}).state('index',{
url:'/index',
templateUrl:'router5.html',
controller:'ctrl5'
}).state('list',{
url:'/list',
template:'<h2>This is a page of list !</h2>'
});
$urlRouter.otherwise('');
}]);
mymodule5.controller('ctrl5',['$scope','$state',function($scope,$state){
$scope.go=function(){
$state.go('list');
}
}])
/*6:uiRouter路由参数设置和$stateParams服务的使用,获取路由地址中的参数值,需要借助$stateParams服务,步骤:->路由地址中指定接收的参数->模板URL地址生成时,传入参数值->通过$stateParams服务获取参数值*/
var mymodule6=angular.module('module6',['ui-router']);
mymodule6.config(['$stateProvider','urlRouterProvider',function($state,$urlRouter){
$state.state('default',{
url:'',
template:'router6.html',
controller:'ctrl6'
}).state('list',{
url:'/list/{id}',
template:'<p>UserName:{{user.name}}</p>',
controller:'ctrl6'
});
$urlRouter.otherwise('/list');
}]);
mymodule6.controller('ctrl6',['$scope','$http','$stateParams',function($scope,$http,$stateParams){
$http({
method:'get',
url:'http://localhost/ajax.php',
cache:true,
}).then(function(res){
$scope.data=res.data;
let id=$stateParams.id;
if(id){
$scope.data.forEach(function(v){
if(v.id==id) $scope.user=v;
});
}
});
}]);
</script>
</body>
</html>
Angular.js之Router学习笔记的更多相关文章
- 关于Angular.js Routing 的学习笔记(实现单页应用)
最近开始学习angular.js,发现angular.js确实很方便,也很强大.在看到 AngularJS Routing and Multiple Views 这一部分的时候,有点乱.现在通过记录一 ...
- Angular.js之指令学习笔记
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"& ...
- 【09-23】js原型继承学习笔记
js原型继承学习笔记 function funcA(){ this.a="prototype a"; } var b=new funcA(); b.a="object a ...
- Underscore.js 源码学习笔记(下)
上接 Underscore.js 源码学习笔记(上) === 756 行开始 函数部分. var executeBound = function(sourceFunc, boundFunc, cont ...
- Underscore.js 源码学习笔记(上)
版本 Underscore.js 1.9.1 一共 1693 行.注释我就删了,太长了… 整体是一个 (function() {...}()); 这样的东西,我们应该知道这是一个 IIFE(立即执行 ...
- 浏览器中js执行机制学习笔记
浏览器中js执行机制学习笔记 RiverSouthMan关注 0.0772019.05.15 20:56:37字数 872阅读 291 同步任务 当一个脚本第一次执行的时候,js引擎会解析这段代码,并 ...
- 纯JS实现KeyboardNav(学习笔记)一
纯JS实现KeyboardNav(学习笔记)一 这篇博客只是自己的学习笔记,供日后复习所用,没有经过精心排版,也没有按逻辑编写 GitHub项目源码 预览地址 最终效果 KeyboardNav使用指南 ...
- 纯JS实现KeyboardNav(学习笔记)二
纯JS实现KeyboardNav(学习笔记)二 这篇博客只是自己的学习笔记,供日后复习所用,没有经过精心排版,也没有按逻辑编写 这篇主要是添加css,优化js编写逻辑和代码排版 GitHub项目源码 ...
- Angular.js 以及个人学习网站
Angular.js 教程 http://www.360doc.com/content/14/0414/15/14416931_368816305.shtml web前端学习: 慕课网:http:/ ...
随机推荐
- 拓扑排序(Topological)
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> #include<stack&g ...
- 在asp.net中使用ajax记录
一.问题描述 ajax在mvc中使用频繁,比如cms中的评论功能,但由于涉及到前后端开发,日久容易忘,在此做下记录. 二.内容 控制器中代码示例: /// <summary> /// 在文 ...
- delphi下实现控制其它窗体中的控件代码模板(delphi 7安装程序)
unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms ...
- 手动清除memcached缓存方法
1.查memcache状态/usr/bin/perl /usr/local/src/memcached-1.4.5/scripts/memcached-tool localhost:11211或者te ...
- HTML 颜色值
HTML 颜色值 颜色由红(R).绿(G).蓝(B)组成. 颜色值 颜色值由十六进制来表示红.绿.蓝(RGB). 每个颜色的最低值为0(十六进制为00),最高值为255(十六进制为FF). 十六进制值 ...
- jQuery 动画的执行
jQuery 动画的执行 <%@ page language="java" import="java.util.*" pageEncoding=" ...
- Gdb远程调试Linux内核遇到的Bug
知识共享许可协议本作品采用知识共享署名 4.0 国际许可协议进行许可.转载保留声明头部与原文链接https://luzeshu.com/blog/gdb-bug 本博客同步在http://www.cn ...
- 游戏开发之在UE4中编写C++代码控制角色
当你运行我们上次做完的项目,你可能会意识到我们移动的摄像机还是默认的那个摄像机,这个默认的摄像机可以自由飞翔.这一节,我们要使得开始的角色是我们的一个Avatar类的实例对象,并且使用键盘控制我们的角 ...
- python属性查找(attribute lookup)
在Python中,属性查找(attribute lookup)是比较复杂的,特别是涉及到描述符descriptor的时候. 在上一文章末尾,给出了一段代码,就涉及到descriptor与att ...
- 我的音乐盒子(nodejs7 + koa2 + vue + vuex + vue-router)
你们知道的,nodejs对jser来说,是个好东西,快快的,自从接触nodejs后,总想弄点东西. 这弄个啥了,一天打开百度音乐盒,哟,自己弄一个如何了,好啊好啊. 后台: nodejs 7 + ko ...