AngularJs学习笔记7——四大特性之模块化设计
模块化设计
1.引用自定义模块并调用
自定义模块中,如果有一些服务、封装好笑模块,在另外一个模块中(声明的时候,在依赖列表中加入要引入的模块)
var app02 = angular.module('fan02',['ng','fan']);
就调用fan02模块中所定义的东西
2.ng内置的模块的用法
(1) ngRoute模块(路由模块)
AngularJS是一个开源的js框架。用在数据操作比较频繁的场景下,用于SPA应用
单页面应用的工作原理:
1.页面url:http://127.0.0.1/index.html#/路由地址
2.浏览器首先解析基础页面index.html,再解析路由地址
3.查找路由词典,#/startàstart.html#/mainàmain.html
4.得到当前url中路由地址所对应的真实模板页面地址
5.发起ajax请求,获取目标模板页面,插入到当前的DOM树
使用ngRoute来实现SPA的步骤
1.创建一个完整的HTML页面,引入angular.js、angular-route.js
2.创建自定义模块,在依赖列表中依赖ng,ngRoute
3.在index.html的body中声明一个容器(盛放代码片段)
实现方式:使用ngView指令声明一个容器
4.创建代码片段
5.配置路由词典
$routeProvider.when(‘/start’,{templateUrl:‘start.html’});
6.测试
使用SPA,怎么实现页面间的跳转
1.修改地址栏中的路由地址
2.超链接
3.js
$location.path(‘路由地址’);
调用控制器的时候,有两种方式:
1.直接使用ng-controller=’’
2.在路由词典中,在对应路由地址的对象中添加controller属性:controller:’’;
如果多个控制器需要用到相同的变量或者方法,可以将它放在父元素所对应的控制器中;子元素是可以调用父元素中定义好的方法或者变量。(parentCtrl)
SPA,如何实现带参数的模板页面间的跳转
1.分清发送方和接收方
发送方:’/start/200’
接收方:
2.配置接收方路由
.when('/myPay/:price',{templateUrl:'tpl/pay.html'})
3.发送
<a href='#/myPay/200'></a>
4.接收到参数
$routeParams.price
AngularJs学习笔记7——四大特性之模块化设计的更多相关文章
- AngularJs学习笔记2——四大特性之MVC
angularJs的四大特性 ①.采用MVC的设计模式 ②.双向数据绑定 ③.依赖注入 ④.模块化设计 现在细说一下MVC的设计模式: MVC: Model(模型)--项目中的数据 View(视图)- ...
- AngularJs学习笔记6——四大特性之依赖注入
压缩工具:YUI-compressor 为了优化网页功能,对一些脚本文件进行压缩,比如:删除所有的注释和空格等,简化形参.但是AngularJs模块中可以声明多种组件,如控制器.指令.过滤器.服务等. ...
- AngularJs学习笔记4——四大特性之双向数据绑定
双向数据绑定 方向1:模型数据(model)绑定到视图(view) 实现方法:①.{{model变量名}} ②.常用指令(ng-repeat) 方向2:将视图(view)中用户输入的数据绑定到模型数 ...
- AngularJs学习笔记--Forms
原版地址:http://code.angularjs.org/1.0.2/docs/guide/forms 控件(input.select.textarea)是用户输入数据的一种方式.Form(表单) ...
- AngularJs学习笔记--concepts(概念)
原版地址:http://code.angularjs.org/1.0.2/docs/guide/concepts 继续.. 一.总括 本文主要是angular组件(components)的概览,并说明 ...
- AngularJS学习笔记2——AngularJS的初始化
本文主要介绍AngularJS的自动初始化以及在必要的适合如何手动初始化. Angular <script> Tag 下面通过一小段代码来介绍推荐的自动初始化过程: <!doctyp ...
- AngularJs学习笔记--Using $location
原版地址:http://code.angularjs.org/1.0.2/docs/guide/dev_guide.services.$location 一.What does it do? $loc ...
- AngularJs学习笔记--Injecting Services Into Controllers
原版地址:http://docs.angularjs.org/guide/dev_guide.services.injecting_controllers 把service当作被依赖的资源加载到con ...
- AngularJs学习笔记--I18n/L10n
原版地址:http://code.angularjs.org/1.0.2/docs/guide/i18n 一.I18n and L10n in AngularJS 1. 什么是I18n和L10n? 国 ...
随机推荐
- 获取web路径的几种方式
1.string str1 = Request.ApplicationPath.ToString(); 返回路径为:\HolterClientWeb 2.HttpServerUti ...
- JDBC连接Oracle数据库时出现的ORA-12505错误及解决办法
转载至http://www.blogjava.net/itspy/archive/2007/12/20/169072.html Oracle 问题描述:今天使用jdbc连接oracle 10.2.0. ...
- eclipse中build path 中JDK与java compiler compliance level的问题(转)
roject facets做什么用? http://baike.baidu.com/view/6257360.htm,其实我感觉,就是让我们在创建项目时候,可以独立定义一个有一个模板供我们使用,在里面 ...
- Css Div半透明
用CSS控制外层DIV不透明,而内层DIV透明,这样实现的效果是意想不到的,还不错吧,其实代码也是很简单的,也很好理解,主要是用了CSS的滤镜. <html xmlns="http:/ ...
- 取消IDEA中光标“指哪打哪”模式
很简单,在Settings->Editor里面去掉Allow placement of caret after end of line
- PHPCMSV9 更改后台地址
修改PHPCMS v9默认后台登录地址 1.修改admin.php文件名,并修改跳转地址写上完整路径2.修改 /phpcms/modules/admin/classes/index.php,把 pub ...
- PHP自动添加http://头 转换网址为链接
有时候,当我们需要用户输入网址的时候,一般我们会让用户省略掉"http://",当提交完成后用代码自动再加上http://,若有需要,我们 还可将网址转换成链接的形式,类似于众多网 ...
- php stripslashes() addslashes() 解析
stripslashes() 函数删除由 addslashes() 函数添加的反斜杠. 实例: <?php $str = "Is your name O\'reilly?"; ...
- 插入排序(C语言)
输入一个数,插入到已排序的队列中 第一:定义一个已经排好的整型数组 如: int arry[7]={2,3,5,11,15,17}; 或输入一串整型的数组,再排序(冒泡.选择都可以) 下面我们用冒泡 ...
- IOS编程教程(八):在你的应用程序添加启动画面
IOS编程教程(八):在你的应用程序添加启动画面 虽然你可能认为你需要编写闪屏的代码,苹果已经可以非常轻松地把它做在Xcode中.不需要任何编码.你只需要做的是设置一些配置. 什么是闪屏 对于那些 ...