AngularJS压缩JS技巧分析
本文实例讲述了AngularJS压缩JS的操作技巧。分享给大家供大家参考,具体如下:
大多数web项目在发布时候都会对js代码进行压缩,目的是为了减少js文件的大小,节省一点流量。
它的原理很简单,就是对参数及部分变量名和函数进行重命名。
但是这种工作方式在AngularJS的应用中会有例外。
由于AngularJS的依赖注入是根据参数名进行注入的,显然,对参数进行重命名会破坏这个机制。
如果不进行特殊处理,进行压缩(minify)之后,在执行时将会出现这样的错误
Unknow provider: aProvider<-a
对于这种错误的官方解释是:找不到依赖的服务
也就是说这种依赖注入会出现错误。
好在AngularJS内置了一种标准机制来处理这个问题.
最简单也最常见的方式就是用数组代替函数。如:
.controller('RegisterCtrl', ['$scope', '$interval', '$timeout', function ($scope, $interval, $timeout) {
//do something
}]);
数组的最后一个元素始终是一个函数,而前面几个参数都是字符串,和这个函数中的参数一一对应。
另一种形式便是所谓的Annotation方式。如
var objCtrl = function($scope, $timeout, $interval){
// do something
}
//给objCtrl函数增加一个$inject属性,它是一个数组,定义了需要被注入的对象
objCtrl.$inject = ['$scope', '$interval', '$timeout'];
这里的依赖注入形式不仅限于Controller,一切需要DI(依赖注入的directive、factory、services等)都可以采用这两种方式。
希望本文所述对大家AngularJS程序设计有所帮助。
相关文章
Angular4学习之Angular CLI的安装与使用教程
网上很多教程过时,命令在angular4中不适用等等,所以下面这篇文章主要给大家介绍了关于Angular4学习之Angular CLI的安装与使用教程的相关资料,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。2018-01-01
AngularJS验证信息框架的封装插件用法【w5cValidator扩展插件】
这篇文章主要介绍了AngularJS验证信息框架的封装插件用法,分析了AngularJS表单验证规则并实例说明了w5cValidator扩展插件的相关使用技巧,需要的朋友可以参考下2016-11-11
Material(包括Material Icon)在Angular2中的使用详解
这篇文章主要介绍了Material(包括Material Icon)在Angular2中的使用,需要的朋友可以参考下2018-02-02
Angular 2父子组件数据传递之@Input和@Output详解(下)
这篇文章主要给大家介绍了关于Angular 2父子组件数据传递之@Input和@Output的相关资料,文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。2017-07-07
AngularJS模糊查询功能实现代码(过滤内容下拉菜单排序过滤敏感字符验证判断后添加表格信息)
最近做项目遇到这样的需求,要求添加球员的功能,具体样式没做具体要求,下面小编给大家带来了AngularJS模糊查询功能实现代码(过滤内容下拉菜单排序过滤敏感字符验证判断后添加表格信息),感兴趣的朋友一起看看吧2017-10-10


最新评论