AngularJS入门之如何快速上手(详细讲解什么是angular)

来源:互联网 发布:php is_string 编辑:程序博客网 时间:2024/06/08 01:10

标签: angular轮播购物车进度条bootstrap

简介:
AngularJS (ng)诞生于2009年
由Misko Hevery 等人创建
后为Google所收购
(PS:下载angular项目所用到的所有js路径:http://download.csdn.NET/download/zhaohaixin0418/9672039)
概述:
AngularJS(ng)是一个纯JS框架,AngularJS易于构建CRUD应用(CRUD意思是增删改查)
适用于以数据操作为主的SPA(Single Page Application)应用。
基于jQuery对传统的DOM操作进行进一步的封装—使用MVC操作代替了所有的DOM操作。
不再是“先查找元素再操作元素”,
所有的操作都是以“业务数据“为中心
搭建环境:
使用 AngularJS 的步骤:
1.引入必需的js文件 : angular.js
2.为父元素声明ngApp属性(这里的父元素一般指html)(系统会自动载入或启动一个NG应用,这个ngApp是唯一的,只能有一个)
3.为父元素内部使用angularJS相关内容
4.

<!DOCTYPE html><html lang="en" ng-app="haixin"><head>    <meta charset="UTF-8">    <title>ng</title>        <!--[if lte IE 9]>    <script src="public/js/html5shiv.min.js"></script>    <script src="public/js/respond.min.js"></script>    <![endif]-->    <script src="public/js/jquery-2.2.3.min.js"></script>    <script src="public/js/bootstrap.js"></script>    <script src="public/js/angular.js"></script>    <link rel="stylesheet" href="public/css/bootstrap.css">    <link rel="stylesheet" href="public/css/animation.css"></head><body></body></html>

ng四大特性:
1.采用MVC模式,页面中再也无需出现DOM操作。
2.双向数据绑定。
3.依赖注入
4.模块化设计
ng四大特性之一MVC模式
(1)Model: 模型,指业务数据,web项目中由js变量担当model。
(2)View: 视图,用户界面,HTML
(3)Controller: 控制器,Function
ng指令:
AngularJS 中ng模块提供的指令(directive)
(1) ngApp:自动载入/启动一个AngularJS应用
(2) ngInit:用于声明Model(模型)变量
(3) ngController:创建一个控制器对象的实例
(4) ngBind:在当前元素的innerHTML上输入指定的表达式的值
(5) ngRepeat:为HTML增加循环功能,循环输出当前元素
(6) ngIf:为HTML增加选择功能,只有在表达式值为true时,当前元素才添加到DOM树
(7) ngSrc:解决img等标签的src属性中包含{{}}产生的问题
语法:
(8) ngClick: 为元素绑定监听函数(不是全局函数,而是Model函数)
语法:
(9) 使用scope.=function()(10)ngStyle:Model(11)ngShow/ngHide:displaynone/block(12)ngDisabled:true/false(13)ngChecked:true/falseAngularModelModel(1)使ngInitngInitHTMLngInitModel使ngInitModelngInitModelnumberstringboolean使ngInitModel使newViewModel使(2)使ControllerModel使Module<=Controller<=ModelAngular1)(module)angular.module(,[])2)AngularJSngapp=3)ControllerModelscope.模型变量名 = 值
4)在View中创建Controller对象的实例,指定其作用范围
<标签 ng-controller=“控制器名”>…控制器的有效范围…

<script>    angular.module("haixin",[]).controller("方法名",function($scope){        $scope.mobile1="";        $scope.mobile2="";    })</script>

控制器:
定义对象属性:

<script>    function studentController($scope){        $scope.student={            stu1:"zhangsan",            stu2:"lisi"        }    }</script>

控制器:
定义方法:

<script>    function studentController($scope){        $scope.student={            sName1:"zhangsan",            sName2:"lisi",            allName:function(){                var  n;                n=$scope.student;                return n.sName1+""+n.sName2;            }        }    }</script>

PS:小练习:
(1)创建一个新的页面,其中声明module、controller、model变量:一个学生对象,其中包含sname、gender、birthday、score等属性,在view中显示这些model数据
(2)创建一个新的页面,其中声明module、controller、model变量:5个分数组成的数组,在view中的一个列表中输出这5个数字
(3)五个商品的数据显示在View中的table元素中,使用ngRepeat指令进行循环
案例答案:

<html lang="en" ng-app="haixin"><body>    <section ng-controller="practice">        <p>{{obj}}</p>        <ul>            <li ng-repeat="k in arr">{{k}}</li>            <li ng-repeat="(k,v) in arr">{{k}}:{{v}}</li>        </ul>    </section>    <section ng-controller="commodity">        <table class="table table-bordered table-hover text-center">            <th>序号</th><th>商品名字</th>            <th>商品价格</th><th>商品图片</th>            <tr ng-repeat="i in arr1">                <td>{{$index+1}}</td>                <td>{{i.name}}</td>                <td>{{i.price}}</td>                <td><img ng-src="{{i.img}}" width="60"></td>            </tr>        </table>        <button class="btn btn-block btn-primary" ng-click="add()">点击加载</button>    </section>    <script>    angular.module("haixin",[]).controller("practice",function($scope){        $scope.obj = new Object();        $scope.obj.name = "Tom";        $scope.obj.gender ="boy";        $scope.obj.birthday = "4.18";        $scope.arr=[10,20,30];    }).controller("commodity",function ($scope) {        $scope.arr1=[            {name:"商品1",price:"77",img:"images/1.jpg"},            {name:"商品2",price:"33",img:"images/2.jpg"},            {name:"商品3",price:"55",img:"images/3.jpg"}        ];        $scope.add=function () {            for(var i=0;i<3;i++){                var arr2 ={};                arr2.name="商品";                arr2.price="11";                arr2.img="images/"+(1+i)+".jpg";                $scope.arr1.push(arr2);            }        }    })    </script></body></html>

ng四大特性–双向数据绑定:
方向一:把Model数据绑定到View上
把Model数据绑定到View上后,任何Model数据的修改,都会自动更新到View上({{ }}、ngBind、ngRepeat、ngSrc…都实现了方向1的绑定)
方向二:把View绑定到Model上
把View数据绑定到Model后,任何View数据的修改,都会自动更新到Model上
此后不论任何时候,只要View中的数据一修改,Model中的数据会自动随之修改。实现方法: 只有ngModel指令。
可以使用scope.watch(‘模型变量名’, fn)监视一个模型变量值的改变;单行文本输入域、多行文本输入域、下拉框、单选按钮控件默认会把自己的value属性值绑定到一个Model变量;复选框会把一个true/false值绑定到一个Model变量。
ng模块中提供的服务(service)
(1)rootScope:(2)interval: 提供周期性定时器服务
(3)interval.cancel(t)(4)timeout: 提供一次性定时器服务
(5)$http: 发起异步的Ajax请求服务
定时器小案例:input值改变的时候,控制台也会改变,若只写input和P的时候,input值改变的时候P的内容也跟着改变。
代码如下:

<input type="text" ng-model="Uname"><p>{{name}}</p><script>    $scope.$watch("Uname",function () {        console.log($scope.Uname);    })</script>

PS:小练习
1:简易版的点击次数计算器
2:简易版的轮播广告
3:用Bootstrap组件制作一个进度条(每隔0.2s,前进10%)取消定时:$interval.cancel(t);
4:简易版的购物车
5:同意使用条款,则可以注册,否则禁止注册
6:简易版模拟QQ选择切换头像
7:全选或取消全选(PS:4,5,6,7这四个小练习是双向数据绑定了,直接加ng指令就可实现。下面案例中图片名字一律为n.jpg【n 为正整数】)
案例代码如下:

<html lang="en" ng-app="haixin"><body><section class="container">    <section ng-controller="lunbo">        <p>{{n}}</p>        <button class="btn btn-danger" ng-click="fn()">点击加一</button><br/>        <img ng-src="images/{{img}}.jpg" alt="" width="300">        <button class="btn btn-success" ng-click="prev()">上一个</button>        <button class="btn btn-success" ng-click="next()">下一个</button>    </section>    <section class="progress" ng-controller="jindutiao">            <div class="progress-bar" role="progressbar" aria-valuenow="85" aria-valuemin="0" aria-valuemax="100"                 ng-style="myStyle"></div>    </section>    <section ng-controller="a2">        <form>            单价:<input type="number" placeholder="请输入价钱" ng-model="price">            数量:<input type="number" placeholder="请输入数量" ng-model="num">            小计:<span>{{price*num}}</span>        </form>        <input type="checkbox" ng-model="agree">我同意本站的使用条款        <button class="btn btn-success" ng-disabled="!agree">提交注册</button>        <button class="btn btn-danger" ng-if="agree">提交注册</button>        <button class="btn btn-primary" ng-show="agree">提交注册</button>        <select ng-model="pic">            <option value="images/1.jpg">帅锅</option>            <option value="images/2.jpg">蕾女</option>            <option value="images/3.jpg">大爷</option>            <option value="images/4.jpg">大叔</option>        </select>        <span><img ng-src={{pic}} width="200"></span>        <aside>            <input type="checkbox" ng-checked="checkAll">A            <input type="checkbox" ng-checked="checkAll">B            <input type="checkbox" ng-checked="checkAll">C            <input type="checkbox" ng-model="checkAll">            <span ng-hide="checkAll">全选</span>            <span ng-show="checkAll">取消全选</span>        </aside>    </section></section><script>    angular.module("haixin",[]).controller("lunbo",function ($scope) {        $scope.n = 10;        $scope.fn=function () {            $scope.n++;        };        $scope.img =1;        $scope.next=function () {            $scope.img++;            if($scope.img==5){                $scope.img=1;            }        };        $scope.prev=function () {          $scope.img--;            if($scope.img<1){                $scope.img=4;            }        }    }).controller("jindutiao",function ($scope,$interval) {        $scope.n=10;        $scope.myStyle={"width":"0%"};        var t = $interval(function () {            $scope.myStyle.width=$scope.n+"%";            $scope.n+=10;            if($scope.n==90){                $interval.cancel(t);            }        },200)    })</script></body>

ng四大特性之—依赖注入
依赖: Driver对象的创建和运行必需一个car对象,称为Driver对象“依赖于”Car对象。依赖注入体现着“最少知识法则”
依赖对象的解决方法:
(1)主动创建

var c=new Car();   //创建被依赖的对象    var d=new Driver(c); //使用被依赖的对象

(2)被动注入(inject)
一般由特定框架来创建Driver对象,发现其依赖于一个Car对象,框架自动创建被依赖的Car对象——称为“依赖注入”。
依赖注入的典型例子:

angular.module.controller('控制器名', function( $scope, $http ){ })

注意:
控制器对象的构造函数是由AngularJS来调用的,不能手动调用
Angular会根据控制器对象的构造函数的形参名来创建依赖的参数对象——形参名不能随意指定!
若控制器对象未声明形参,则Angular不会传递任何实参进来
控制器对象的形参名(PS:此处的形参名是不能够随意定的)必需是Angular可识别的,但数量和顺序都没有限制—Angular会根据每一个形参的名称来查找创建被依赖的对象,并自动注入进来。
ng四大特性之—模块化设计:
模块化设计体现着“高内聚低耦合”设计原则。
项目中,可以根据功能的不同,将不同的组件放置在不同的模块中
AngularJS中有两种模块:
(1)AngularJS官方提供的模块:ng、ngRoute、ngAnimate、ngTouch、….
(2)用户自定义的模块:userModule、productModule、orderModule、….
一个NG模块中可以包含多个组件:
(1)controller组件:用于维护模型数据
(2)directive组件:用于在View中输出/绑定Model数据
(3)service组件:用于在不同的控制器中提供某种函数服务
(4)filter组件:用于对View中输出的数据进行格式化
……..
Filter组件 (过滤器):
用于Model数据在View中呈现时进行某种格式的筛选/过滤/格式化。
在View中使用过滤器时,需要借助于管道:|
ng模块中提供的过滤器:(ps:HH指的是24小时制)
(1)lowercase:把数据格式化为小写
(2)uppercase:把数据格式化为大写
(3)number:把数字型数据格式化为三位一个逗号的字符串同时指定小数点位数 eg: {{price | number : 2 }}
(4)currency:把数字型数据格式化为货币格式的字符串,同时指定货币符号 eg: {{price | currency : ‘¥’ }}
(5)date:把数字/Date型数据格式化为特定日期时间格式的字符串

<p>{{name | lowercase}}</p>    <p>{{name | uppercase}}</p>    <p>{{num  | number:2}}</p>    <p>{{num  | currency:"¥"}}</p>    <p>{{time | date:"yyyy年MM月dd日 HH时mm分ss秒"}}</p>    <p>{{time | date:"yyyy-MM-dd HH:mm:ss"}}</p>

PS案例:点击一个按钮“加载员工数据”,向服务器发起异步的Ajax请求,获取服务端的一段JSON数据,显示在一个表格中(注意数据格式);加载完数据后,按钮即禁用/消失。
案例答案:

<!DOCTYPE html><html ng-app="haixin"><head lang="en">    <meta charset="UTF-8">    <title>Title</title>    <link rel="stylesheet" href="../css/bootstrap.css"></head><body><section class="container" ng-controller="a1">    <table class="table table-bordered table-hover">        <tr>            <th>序号</th>            <th>姓名</th>            <th>工资</th>            <th>入职日期</th>        </tr>        <tr ng-repeat="j in pro">            <td>{{$index+1}}</td>            <td>{{j.ename}}</td>            <td>{{j.salary |number}}</td>            <td>{{j.hiredate |date:"yyyy年MM月dd日"}}</td>        </tr>    </table>    <button ng-click="add()" class="btn btn-block btn-success" ng-disabled="tab">点击</button></section><script src="../js/jquery-1.11.3.js"></script><script src="../js/bootstrap.js"></script><script src="../js/angular.js"></script><script>    angular.module("haixin",[]).controller("a1",function ($scope,$http) {        $scope.tab = false;        $scope.add=function () {            $scope.tab = true;            $http.get("1.json").success(function (data) {                $scope.pro=data;            });        }    })</script></body></html>

JSON文件:

[  {"ename":"Tom", "salary":456765,"hiredate":22224352345},  {"ename":"Mary", "salary":232323,"hiredate":234798237823},  {"ename":"John", "salary":8875645,"hiredate":23423478923},  {"ename":"King", "salary":34325546,"hiredate":772374234333},  {"ename":"Allen", "salary":86756453234,"hiredate":237643274234}]

Angular官方提供的模块之二——ngRoute模块
ngRoute模块可以让用户自定义“路由字典”,自动解析请求URL中的路由地址,查找路由字典,自动发起异步AJAX请求,把获取的结果放在当前页面中。
Route:路由,为到达目的地而经过的线路
(1)页面URL形如: http://127.0.0.1/index.html#/路由地址
(2)浏览器首先请求基础页面(index.html),再解析URL中的路由地址
(3)查找路由字典,形如:
#/start =》 tpl/start.html

/main =》 tpl/main.html

….
获取当前URL中路由地址所对应的真实模板页面的地址
(4)客户端发起异步AJAX请求,获取目标模板页面,将服务器返回HTML片段(只含有几个div),插入到当前的DOM树上。
使用ngRoute模块的步骤:
(1)创建唯一完整的页面: index.html,引入angular.js和angular-route.js
(2)在index.html的body中使用ngView指令声明一个容器元素,用于盛放模板页面
(3)创建自定义模块,声明依赖于ng和ngRoute两个模块
(4)在当前模块中使用ngRoute提供的对象配置路由字典

 angular.module("haixin",[]).config(function($routeProvider){    $routeProvider.when("/路由地址", {        templateUrl:"模板页面URL"    }).otherwise({        redirectTo:"/路由地址"    }) })

(5)再创建几个模板页面,只需要有div元素即可
(6)测试路由字典的配置是否正确
使用ngRoute模块需要注意的问题:

(1)由于模板页面被客户端请求后挂载在index.htmlDOM树上,所以其中所有的图片等外部资源文件的路径必须相对于index.html,而不是模板页面。

(2)使用ngRoute模块时,无需为模板页面中的某个元素单独设置ngController,只需要在声明路由字典时设置整个模板页面所需要的控制器即可

 .when('/路由地址', {    templateUrl: 'xxx.html',    controller: '控制器名' })

(3)在不同的模板页面间跳转可以采用两种方式:·超链接方式:

 $scope.jump = function(){    $location.path('/路由地址'); }

(4) index.html中,由于所有模板页面都是在ngView中切换,ngView外面的内容会始终呈现。
官方提供的模块——ngAnimate
ngAnimate可以支持JS、Transition、Keyframes动画,但它本身未提供任何的动画效果,而是为上面三种技术提供了相应的“动画钩子(Hooks)”

ng模块中提供的指令:ngRepeat, ngInclude, ngIf, ngSwitch, ngShow, ngHide, ngView 和 ngClass默认都提供了动画钩子。

使用ngAnimate模块调用其CSS Transition动画钩子的步骤:

(1) index.html引入angular.js和angular-animate.js。

(2) 自定义模块中声明依赖于ngAnimate模块——特定的指令就会产生动画钩子。

(3) 为ngView声明class,样式中指定transition动画;

可以看到ngAnimate为即将要离开的ngView添加了 ng-leave和ng-leave-active 两个class,为即将要进入的ngView添加了 ng-enter和

ng-enter-active两个class。为这四个class编写特定的样式即可。

(PS:这里只是普通的进出动画,其实可以更炫点,每个页面都有
进出的动画,这个就是后期要研究的,可以充分利用C3一些特效)

.page {  transition: all 2s linear;  position: absolute;  width: 100%;}/*要离开的ngView元素动画开始时的样式*/.page.ng-leave {  left: 0;}/*要离开的ngView元素动画结束时的样式*/.page.ng-leave.ng-leave-active {  left: -100%;}/*要进入的ngView元素动画开始时的样式*/.page.ng-enter {  left: 100%;  top: 100%;  transform: scale(0.9);}/*要进入的ngView元素动画结束时的样式*/.page.ng-enter.ng-enter-active {  left: 0;  top: 0;}

ng 表达式:
ng 表达式写在双大括号内:{{ expression }}。
ng 表达式把数据绑定到 HTML,这与ng-bind指令有异曲同工之妙。
ng 将在表达式书写的位置”输出”数据。
ng 表达式很像JavaScript 表达式:它们可以包含文字、运算符和变量。
实例 :{{ 5 + 5 }} 或 {{ firstName + ” ” + lastName }}

0 0
原创粉丝点击