angular js学习笔记
2016-01-28 12:19
495 查看
参考教程:
https://xdsnet.gitbooks.io/angular-phonecat-book-zhcn/content/chapter4/chapter4.html
安装依赖:npm install
运行程序: npm start
运行karma单元测试: npm test
运行protractor端到端测试: npm run protractor
phonecatApp.controller(‘PhoneListCtrl’, function (scope,scope, http) {…}
因为Angular的依赖控制采用了以名字作为构造函数的参数传入机制运行,所以如果你想压缩你的PhoneListCtrl控制器部分JavaScript代码就需要注意一些细节,否则自动机制下所有的参数名会自动压缩而导致依赖注入功能出错。
对于这样的问题就是提供一个禁止压缩的依赖名称列表,这样列表中的名称在压缩时不会进行缩减替换,这样就能保证压缩后的代码能够正常工作了,对此有两个方法:
方法一:在控制器构造函数上创建一个inject(注入)字符串数组,数组中每个字符串都是需要注入的服务名。在我们的例子中就是这样写:
方法二:使用内联注解语句,函数不是仅仅提供功能要求,还包括一个功能名的字符串数组(内联注解数组),例如:
这两种方法都可以被Angular正常识别进行注入,所以你只需要依据你项目风格选择一种即可。
当采用第二种方式,通常定义一个内联的匿名函数供注册器实施注入:
从现在开始,教程中我们将采用内联注解方式(第二种方法)进行处理,使得代码支持压缩。让我们为PhoneListCtrl添加一个内联注解: app/js/controllers.js:
https://xdsnet.gitbooks.io/angular-phonecat-book-zhcn/content/chapter4/chapter4.html
安装依赖:npm install
运行程序: npm start
运行karma单元测试: npm test
运行protractor端到端测试: npm run protractor
学习笔记:
1.为了使用Angular服务,你只用在控制器中需要的地方简单把调用名字作为构造函数的参数,例如:phonecatApp.controller(‘PhoneListCtrl’, function (scope,scope, http) {…}
因为Angular的依赖控制采用了以名字作为构造函数的参数传入机制运行,所以如果你想压缩你的PhoneListCtrl控制器部分JavaScript代码就需要注意一些细节,否则自动机制下所有的参数名会自动压缩而导致依赖注入功能出错。
对于这样的问题就是提供一个禁止压缩的依赖名称列表,这样列表中的名称在压缩时不会进行缩减替换,这样就能保证压缩后的代码能够正常工作了,对此有两个方法:
方法一:在控制器构造函数上创建一个inject(注入)字符串数组,数组中每个字符串都是需要注入的服务名。在我们的例子中就是这样写:
function PhoneListCtrl($scope, $http) {...} PhoneListCtrl.$inject = ['$scope', '$http']; phonecatApp.controller('PhoneListCtrl', PhoneListCtrl);
方法二:使用内联注解语句,函数不是仅仅提供功能要求,还包括一个功能名的字符串数组(内联注解数组),例如:
function PhoneListCtrl($scope, $http) {...} phonecatApp.controller('PhoneListCtrl', ['$scope', '$http', PhoneListCtrl]);
这两种方法都可以被Angular正常识别进行注入,所以你只需要依据你项目风格选择一种即可。
当采用第二种方式,通常定义一个内联的匿名函数供注册器实施注入:
phonecatApp.controller('PhoneListCtrl', ['$scope', '$http', function($scope, $http) {...}]);
从现在开始,教程中我们将采用内联注解方式(第二种方法)进行处理,使得代码支持压缩。让我们为PhoneListCtrl添加一个内联注解: app/js/controllers.js:
var phonecatApp = angular.module('phonecatApp', []); phonecatApp.controller('PhoneListCtrl', ['$scope', '$http', function ($scope, $http) { $http.get('phones/phones.json').success(function(data) { $scope.phones = data; }); $scope.orderProp = 'age'; }]);
相关文章推荐
- title属性中的内容包含大于号和小于号, 如何替换?
- [转]js中的时间与毫秒数互相转换
- 读书笔记 JavaScript 高级程序设计(第三版)-- 第1章
- [转]javascript Date format(js日期格式化)
- input类型
- js正则表单验证汇总,邮箱验证,日期验证,电话号码验证,url验证,信用卡验证,qq验证
- 在JSP中使用常量
- JS时间控件-laydate
- 基于JavaScript的操作系统你听说过吗?
- js+canvas绘制矩形的方法
- ajax 和 json
- 读大叔js,摘抄——单例模式
- js+canvas简单绘制圆圈的方法
- iOS插件化研究之中的一个——JavaScriptCore
- 谈一谈javascript闭包
- js 事件监听 兼容浏览器
- javascript中有趣的面向对象的思想
- js DOM事件详解
- JavaScript统计字符串中每个字符出现次数完整实例
- JavaScript btoa atob