今天咱们继续来说angular
angular指令
angular指令就是其内置的一些方法。均以ng-XXX来表示,比如前面见到的ng-controller,ng-model,ng-app等等。
其中ng-app是angualr的初始化指令,如果不写,那么整个页面关于angular的JS都不会起作用的哦!你可以把它写在HTML标签上,也可以写在局部的Div身上。这样子你就可以灵活的控制需要使用angular的地方了。
双向数据绑定
Angular是MVVM模式,即双向数据绑定,也就是说数据的改变可以影响到视图,视图的改变可以影响到数据的改变,这就是双向数据绑定。咱们来看看代码:
html
<body> <div ng-controller="hockor"> <p>hello {{name}}</p> </div> <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script> <script> "use strict"; function hockor($scope,$timeout) { $scope.name = "world"; $timeout(function () { $scope.name = "hockor"; }, 3000) } </script> </body>
执行的效果如下
看看,是不是数据的改变就影响视图的改变了!
PS:代码中的$timeout就相当于JS中的setTimeout一样,但是如果你在这里写js中的setTimeout是无效的哦,必须按angular的来写。
再来看一个:
html
<body> <div ng-controller="hockor" ng-click="name='click'"> <p>hello {{name}}</p> </div> <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script> <script> "use strict"; function hockor($scope,$timeout) { $scope.name = "world"; } </script> </body>
其中效果的变化是我点击触发的(录制gif的原因。看不到鼠标效果)。
购物车实例
接下来我们看看angular中的过滤器,并且做一个小例子!
要求:完成一个简单的购物车,当用户总价大于100元时,运费为0;
html
<body> <div ng-controller="hockor"> <p>单价: <label> <input type="text" ng-model="iphone.money"/> </label> </p> <p>数量: <label> <input type="text" ng-model="iphone.num"/> </label> </p> <p>费用: <span>{{sum() | currency:'¥'}}</span></p> <p>运费:<span>{{iphone.free | currency:'¥'}}</span></p> <p>总额:<span>{{sum() + iphone.free | currency:'¥'}}</span></p> </div> <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script> <script> "use strict"; function hockor($scope) { $scope.iphone = { money : 50, num : 1, free : 10 }; $scope.sum = function () { return $scope.iphone.money*$scope.iphone.num; }; //watch普通监听只能监听单个值,如果想监听一个集合,需要第三个参数true $scope.$watch($scope.sum,function(newval,oldval) { //形参中的newval和oldval分别表示监听数据的最新值和修改前的值 $scope.iphone.free = newval >= 100 ? 0 : 10; },true);//此处的true可写可不写 } </script> </body>
以上的代码就是实现一个小的购物车的例子。实际效果入下:
注意:其中的currency是货币的标识。通过 | 进行管道传输(类似于linux的通道),默认是$(美元).可以通过以上方式修改为¥,欧元等等。
原创文章:转载请注明!