Angular双向数据绑定MVVM以及基本模式分析

MVVM:

angular的MVVM实现的是双向数据绑定,模型从服务器端抓取到数据,将数据通过控制器(controller)传递到视图(view)显示,视图数据发生变化时同样也会影响到模型数据的变化,这既是双向数据绑定。

$scope便是视图模型,controller的作用便是view与model之间的桥梁(纽带)。

 

基本模式分析:

 1  <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4    <meta charset="UTF-8">
 5     <title>test</title>
 6  </head>
 7  <body ng-app="app">    <!-- angular模块 -->
 8  <p ng-controller="myCtr">{{msg}}</p>   <!-- angular控制器 -->
 9  </div>
10  <script src="angular.min.js"></script>
11  <script>
12  var m = angular.module("app", []);                  //加载angular模块,[]表示有其他模块需要加载时才会用到
13  m.controller("myCtr", ["$scope", function($scope){  //定义控制器   推荐使用这种写法,缩后不易出现问题
14     $scope.msg="lol";
15  }]);
16  </script>
17  </body>
18  </html>

注意上述代码,每一句都有加分号,是因为在代码通过gulp压缩后,代码会连在一起,若不加分号,压缩后就无法正常运行了

对比下面的写法:

1 var m = angular.module("app", []); //加载angular模块,[]表示有其他模块需要加载时才会用到
2  m.controller("myCtr", function($scope){ //定义控制器  不建议使用这种写法
3     $scope.msg="lol";
4  });

这种写法是比较精简,但是代码压缩后,形式参数$scope会变成单个字母,如"a"等,这样代码就不能正常运行了,而上面的第一种写法,可以正常运行,所以建议写成第一种

1 angular.module("app", []).controller("myCtr",["$scope", function(a){a.msg="lol";}]); //可以正常运行
2 angular.module("app", []).controller("myCtr", function(a){a.msg="lol"; });            //不能正常运行

所以综上所诉,代码书写注意规范且加 “;”,这样代码在压缩后就不会出现问题了。


    

posted @ 2016-12-20 13:47  孙凯亮  阅读(766)  评论(0编辑  收藏  举报