zoukankan      html  css  js  c++  java
  • AngularJS_01之基础概述、设计原则及MVC设计模式

     

    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";
    ⑤在控制器的回调函数中,注入scopescope对象,指定模型数据:scope.变量=值;
    ⑥显示:
    {{}}——ng指令:
    scopengInitscope作用域控制对象,将模型数据和视图建立联系;初始化数据——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所在的标签内部的作用范围,才能识别控制器所声明的变量、方法;

    It's never too old to learn!
     
     
     
    来自http://www.cnblogs.com/Jupiter258/archive/2016/11/20/6082151.html
  • 相关阅读:
    Merge Sort
    important在css中的作用
    Quick Sort
    Shell's Sort
    2019年7月22日~28日 第四周学习记录
    eclipse安装心得和环境变量配置的体会
    2019年7月15日~7月21日 第三周学习记录
    2019年7月1日~7月7日 第一周学习记录
    程序为本,代码方式仅是语言 ———《大道至简软件工程实践者的思想》
    2019年7月8日~7月14日 第二周学习记录
  • 原文地址:https://www.cnblogs.com/zhoupengyi/p/6082477.html
Copyright © 2011-2022 走看看