1、AngularJS:
开源的JS框架,用来开发单一页面应用,以及数据操作频繁的场景;
2、设计原则:
①YAGNI原则:You Aren't Gonna Need It!
不要写不需要的代码!
②KISS原则:Keep It Simple and Stupid!
代码保持简洁和具有表现力!
——语义化标记、注释、变量或者方法的命名、减少嵌套;
③DRY原则:Don't Repeat Yourself!
模块的封装!
——提高代码复用率,降低测试难度方便后期的迭代和维护;
④high cohesion low coupling:
高内聚低耦合
内聚:一个组件内部不同组成部分之间的关系;
耦合:不同组件之间的关系;
⑤SRP原则:Single Responsibility Principle!
单一责任原则!
⑥OCP原则:Open Closed Principle!
开闭原则!
⑦LCP原则:
最少知识原则!
3、设计模式:
①创建型模式——五种:
工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式;
②结构型模式——七种:
适配器模式、装饰器模式、代理模式、外观模式、、桥接模式、组合模式、享元模式;
③行为模式——十一种:
策略模式、模板方法模式、观察者模式、迭代子模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式、中介者模式、解释器模式;
4、MVC设计模式——组合型设计模式:
①M——model——模型数据;V——view——html视图;C——controller——控制器;
view接收用户操作,然后通知controller(控制器)中对应的方法,对model(数据)进行操作,反过来更新view(视图);
5、AngularJS:
①开源的基于MVC的JS框架,用于以数据操作为主的SPA应用,其四大特征方便数据处理以及模块方便实现SPA应用;
②四大特征:
a、采用MVC的设计模式:
符合当前互联网的发展趋势——职责的细分;
模块化开发——提高代码复用率,降低测试难度,维护方便;
b、双向数据绑定:
AngularJS区别于其他框架的重要特性;
c、依赖注入:
通过注入某些服务或对象,直接调用;
d、模块化设计:
AngularJS框架本身就符合模块化设计,使用框架结合模块、控制器、服务等来实现模块化开发;
③使用:
基础语法:
{{expression}}:可执行括号中的表达式,将结果输出到innerHTML中;
ng-app:自动载入并启动ng应用;
ng-init:初始化数据(变量、对象、数组...);
* ngApp——用来启动ng应用,同时指定angular应用的作用范围,出了范围ng表达式指令无法被执行,且只允许调用ngApp指令一次;
ng常用指令:
ngApp、ngInit、ng-Bind、ngRepeat(让HTML支持循环)、ngIf(让HTML支持选择/判断)、ngShow(true为显示)、ngHide(true为隐藏);
4、ng的MVC使用:
①声明模块:
var app=angular.module('myApp',['ng']);
②注册模块:
ngApp指令:ng-app="myApp";
③声明控制器:
app.controller('myCtrl',function(){});
④使用控制器:
ngController指令:ng-controller="myCtrl";
⑤在控制器的回调函数中,注入$scope对象,指定模型数据:$scope.变量=值;
⑥显示:
{{}}——ng指令:
$scope作用域控制对象,将模型数据和视图建立联系;
初始化数据——ngInit:
$scope对象;
⑦指令:
<ANY ng-XX=''>
<ANY ng-init="变量名=值;变量名=值..."></ANY>——允许声明变量,双向绑定;
<ANY ng-bind="表达式"></ANY>——将指定的表达式的值输出为当前元素的innerHTML;
<ANY ng-repeat="临时变量名 in 对象/数组"></ANY>——为HTML添加循环功能;
<ANY ng-repeat="(下标变量名,值变量名) in 对象/数组"></ANY>——为HTML添加循环功能;
<ANY ng-if="表达式"></ANY>——为HTML添加选择功能;
ng-click、ng-dbclick、ng-focus、ng-blur;
⑧注意:
定义模型数据,必须注入$scope;
ng-controller所在的标签内部的作用范围,才能识别控制器所声明的变量、方法;

AngularJS_01之基础概述、设计原则及MVC设计模式的更多相关文章

  1. java 28 - 1 设计模式 之 面向对象思想设计原则和模版设计模式概述

    在之前的java 23 中,了解过设计模式的单例模式和工厂模式.在这里,介绍下设计模式 面向对象思想设计原则 在实际的开发中,我们要想更深入的了解面向对象思想,就必须熟悉前人总结过的面向对象的思想的设 ...

  2. 面向对象设计思想和MVC设计模式

    虽然之前学习Java时有接触过面向对象的设计思想,但因当时Java没学好.所以导致这两天讲php的面向对象设计时,感到没有头绪,这也反应了我练习少和逻辑能力的不足.而MVC设计思想 面向对象就是要将系 ...

  3. 面向对象程序的设计原则--Head First 设计模式笔记

    一.找出应用中可能需要变化的地方,把它们独立出来,不要和那些不需要变化的代码混在一起. 把会变化的部分取出并“封装”起来,好让其他部分不会受到影响.这样,代码变化引起的不经意后果变少,系统变得更有弹性 ...

  4. Unity3D设计原则

    原则1:单一职责 原则2:里氏替换原则(子类扩展但不改变父类功能) 原则3:依赖倒置原则 原则4:接口隔离原则 原则5:迪米特法则(最少知道原则) 原则6:开闭原则 原则1:单一职责原则 说到单一职责 ...

  5. 连载:面向对象的葵花宝典:思考、技巧与实践(39) - 设计原则 vs 设计模式

    它的设计原则,和设计模式,是否该用它? ============================================================================= 在& ...

  6. JAVA设计模式总结之六大设计原则

    从今年的七月份开始学习设计模式到9月底,设计模式全部学完了,在学习期间,总共过了两篇:第一篇看完设计模式后,感觉只是脑子里面有印象但无法言语.于是决定在看一篇,到9月份第二篇设计模式总于看完了,这一篇 ...

  7. 设计原则:开-闭原则(Open-Closed Principle, OCP)

    开-闭原则就是软件实体应当对扩展开放,对修改关闭.(Software entities should be open for extension,but closed for modification ...

  8. Java设计原则—开闭原则(转)

    原文出自:http://www.cnblogs.com/muzongyan/archive/2010/08/05/1793454.html 开闭原则(Open Closed Principle)是Ja ...

  9. Java设计模式的7种设计原则还有很多人不知道

    前言 其实没有设计模式我们也能完成开发工作.但是为什么需要设计模式呢?让你看起来很牛,没错这个算一个.让你的代码层次感分明,可读性强而且容易维护.让你像我一样有更多的摸鱼划水时间. 可能有人说我一个类 ...

随机推荐

  1. 使用 .NET WinForm 开发所见即所得的 IDE 开发环境,实现不写代码直接生成应用程序

    直接切入正题,这是我09年到11年左右业余时间编写的项目,最初的想法很简单,做一个能拖拖拽拽就直接生成应用程序的工具,不用写代码,把能想到的业务操作全部封装起来,通过配置的方式把这些业务操作组织起来运 ...

  2. AngularJs之九(ending......)

    今天继续angularJs,但也是最后一篇关于它的了,基础部分差不多也就这些,后续有机会再写它的提升部分. 今天要写的也是一个基础的选择列表: 一:使用ng-options,数组进行循环. <d ...

  3. Oracle 数据库知识汇总篇

    Oracle 数据库知识汇总篇(更新中..) 1.安装部署篇 2.管理维护篇 3.数据迁移篇 4.故障处理篇 5.性能调优篇 6.SQL PL/SQL篇 7.考试认证篇 8.原理体系篇 9.架构设计篇 ...

  4. js学习之变量、作用域和内存问题

    js学习之变量.作用域和内存问题 标签(空格分隔): javascript 变量 1.基本类型和引用类型: 基本类型值:Undefined, Null, Boolean, Number, String ...

  5. Phantomjs+Nodejs+Mysql数据抓取(2.抓取图片)

    概要 这篇博客是在上一篇博客Phantomjs+Nodejs+Mysql数据抓取(1.抓取数据) http://blog.csdn.net/jokerkon/article/details/50868 ...

  6. c#比较两个数组的差异

    将DataTable中某一列数据直接转换成数组进行比较,使用的Linq,要引用命名空间using System.Linq; string[] arrRate = dtRate.AsEnumerable ...

  7. [修正] Firemonkey TFrame 存档后,下次载入某些事件连结会消失(但源码还在)

    问题:Firemonkey TFrame 存档后,下次载入某些事件连结会消失(但源码还在) 解决:(暂时方法) type TTestFrame = class(TFrame) public const ...

  8. 安装angular-cli

    最近在学习angular2,并尝试用这个框架来做公司的一个新项目. 终于要开始开发了,等了1个多月. 因为第一次用这个新框架做项目,不太熟悉,就找了angular-cli这个脚手架来搭建项目. 安装了 ...

  9. 微信小程序开发日记——高仿知乎日报(上)

    本人对知乎日报是情有独钟,看我的博客和github就知道了,写了几个不同技术类型的知乎日报APP 要做微信小程序首先要对html,css,js有一定的基础,还有对微信小程序的API也要非常熟悉 我将该 ...

  10. 微信小程序体验(1):携程酒店机票火车票

    在 12 月 28 日微信公开课上,张小龙对微信小程序的形态进行了阐释,小程序有四个特定:无需安装.触手可及.用完即走.无需卸载. 由于携程这种订酒店.火车票和机票等工具性质非常强的服务,非常符合张小 ...