Angular 1.x个人使用的经验小结
前言
angular1.x作为经典的mvc框架,可以创建能够复用的组件,也可进行双向数据绑定。国内的vue.js/avaloon.js都是同类型的框架,之前工作以Angular1.x为主,主要做业务系统,以后工作中技术栈可能以vue为主,在此对Angular1.x的使用做一个简单,这里使用1.5+版本。狼蚁网站SEO优化话不多说,来一起看看详细的介绍
基本概念
1、依赖注入
依赖注入,在angular中到处可见,这里不会照本宣科,只以很直白的方式的简单描述基本使用方式,以$scope注入为例。
创建一个controller,注入$scope,有三种写法
1)隐式注入
function HomeController($scope){};
2)内联注入
app.controller('HomeController',['$scope',function($scope){ }])
3)显式注入
app.controller(‘HomeController',HomeController); HomeController.$inject=[‘$scope']; function HomeController($scope){ }
注意由于第一种注入方式,是通过对函数做toString操作,然后使用正则匹配出参数名称,来实现注入,所以这种方式不能对代码进行压缩混淆处理。
2、directive
指令系统,我认为是angular1.x版本中最强大也是最复杂的部分,angular作者本身做后端出身,所以在整个指令周期也符合语言处理过程经过编译(pile函数,会返回link函数)、链接处理(link函数)。
1)指令最基本配置
app.directive(‘dire',function(){ return function(){ return { template/templateUrl:'', //模版 scope:{} //为true或为对象表示隔离作用域 restrict 'ACEM'//使用方式 link:function(scope,ele,attrs,controllers){} pile:function(ele,attr){return function(){}}//如果此函数存在,link函数会被忽略,因为pile函数会返回link函数 } } });
2)关于绑定策略
独立作用域父子作用域之间交换数据的方式,主要有三种(或说四种)
@绑定,指令属性的值可以使用表达式,得出来的值一定是字符串;
&绑定,表示引用绑定,主要绑定父作用域中函数,实现关注点的注入
=绑定,表示双向数据绑定
<绑定,表示单向绑定
注意对于&绑定的使用,主要是为了实现子作用域到父作用域的传递,个人比较喜欢vue中父子交互的方式props in,event out。所以这里我一般使用 scope.$emit(‘xxx',data),来实现子传父。
3、ponent
ponent是1.5+新增的方法,主要为了往angular2+的过度更自然一些,相当于指令restrict'E'的简化,类似于vue中的ponent,不建议操作dom,一般只用于渲染,建议构建pure ponent。
4、controller
controller可以认为是一个封装程序逻辑的地方,这里和后端mvc中controller的作用类似,拿到modal,渲染模版,在angular中$scope是连接controller和view的桥梁,$scope是实现数据绑定的基础,详见文档,这里不再赘述。
controller创建方式,主要分为静态工厂方法注册和动态注册:
1)静态注册
app.controller(‘HomeController',function(){})
2)动态注册
$controllerProvider.register(“HomeController”,function(){})
注意动态注册是实现按需加载的基础,在项目结构实战模块会基于requirejs 来演示怎么实现动态按需加载controller(也可以使用oclazyload模块实现按需加载)。
5、service
service一般是封装通用代码,所谓通用代码一般是跨controller/directive等使用的代码,所以经常用来封装ajax接口访问、工具接口等。
service创建方式有三种
1)、provider最原始的创建方式,可以注入到config中,加上provider后缀,有固定格式,必须返回$get函数
2)、factory是对provider的封装,直接返回对象即可
3)、service是最简单的创建方式,通过传递构造函数来创建服务。
6、filter
过滤器主要实现对象的格式化
7、router
内置路由模块ngRoute,用的较少,主要因为无法实现复杂路由比如嵌套,多层等,也可以结合ng-include实现类似效果,推荐使用第三方路由模块ui-router,ui-router是基于state的一种路由框架,是使用最多的一种路由模式。
以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对狼蚁SEO的支持。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程