Best Practice AngularJS

/* 用几组简明扼要的代码段及其说明, 展示良好的编程行为, angularjs */

// app.module.js

angular

.module('app', ['ngRoute']);

// logger.js

(function() {

'use strict';

angular

.module('app')

.factory('logger', logger);

function logger() { }

})();

/*

Single Responsibility 单一责任的文件,小函数

* 1个组件, 1个文件, <400LOC (代码行)

* Small Functions,小函数 < 75LOC(1屏幕), 易于重用,维护和测试

用IIFE减少全局变量

* 类和组件, 要包裹在IIFE里面, (立即执行的函数表达式) Immediately Invoked Function Expression .

*减少全局变量, 从而减少这些变量的寿命,和重名

Modules模块定义

避免产生额外的全局变量:

* 在定义module的时候, 用chain,不要用setter语法引入中间变量,

* 在引用module的时候, 用chain + getter语法, 不定义中间变量。

* 一个module只能创建1次, 多次引用

* 用有名函数, 不要用callback, 以避免Nested的callback

*/

/* 在view中:

<div ng-controller="CustomerProductController as ProductVm">

<input ng-model="ProductVm.title"/>

</div>

*/

angular

.module('app')

.controller('CustomerProductController', CustomerProductController);

CustomerProductController.$inject = ['dataservice', 'logger'];

function CustomerProductController($scope, dataservice, logger) {

var vm = this;

vm.refresh = refresh;

vm.search = search;

vm.sessions = [];

vm.title = 'Sessions';

////////////

function refresh() {

}

function search() {

}

$scope.$watch('vm.title', function(current, original) {

$log.info('vm.title was %s', original);

$log.info('vm.title is now %s', current);

});

}

// route-config.js

angular

.module('app')

.config(config);

function config($routeProvider) {

$routeProvider

.when('/customerProduct', {

templateUrl: 'customerProduct.html',

controller: 'CustomerProductController',

controllerAs: 'productVm'

});

}

/*

Controllers

* 在view中用as语法代替$scope, 类似于new一个实例,接近本色的.语法., 避免$parent,

* 在controller自身中, 用vm(view Modal)代替this,避免歧义,并减少$scope,(仅仅剩余在$emit, $broadcast, $on, $watch等少数情况下,必须用$scope)

* 把bindable函数写在前面, 并按照字母排序, 具体的实现放在后面(如果实现只有1行,可以直接写)。

让重要的函数一览无余, 而且与函数的顺序无关。

* 薄controller, 厚service: 尽量把controller的逻辑下放到services,便于重用,和unit test

* 让controller专注到1个view, 不要重用,因为UI经常变,(而让可重用部分下放给service)

* 在route中定义controller和view,而避免在view中直接指定controller(绑死了),这样, 可以灵活地在route中重用view与controller。

*/

// service全部改用factory

angular

.module('app')

.service('logger', logger);

function logger() {

this.logError = function(msg) {

};

}

// factory

angular

.module('app')

.factory('logger', logger);

function logger() {

return {

logError: function(msg) {

}

};

}

/*

Services

* 用factory代替service,

以简化,并保持一致性。

因为,所有的service都是singleton,而且用new来实例化。

*/

function dataService($http, $location, $q, exception, logger) {

var isPrimed = false;

var primePromise;

var service = {

getAvengers: getAvengers,

ready: ready

};

return service;

////////////

function getAvengers() {

}

function ready(nextPromises) {

// implementation details go here

}

}

/*

Factories

* 与Controller一样的地方:(任务要单一, 接口函数放在前面)

*  factory都是singleton, 返回的object包括了其所有接口函数

*/

// dataService.js

angular

.module('app.core')

.factory('dataService', dataService);

dataService.$inject = ['$http', 'logger'];

function dataService($http, logger) {

return {

getAvengers: getAvengers

};

function getAvengers() {

return $http.get('/api/maa')

.then(getAvengersComplete)

.catch(getAvengersFailed);

function getAvengersComplete(response) {

return response.data.results;

}

function getAvengersFailed(error) {

logger.error('XHR Failed for getAvengers.' + error.data);

}

}

}

// controller.js

angular

.module('app.avengers')

.controller('AvengersController', AvengersController);

AvengersController.$inject = ['dataService', 'logger'];

function AvengersController(dataService, logger) {

var vm = this;

vm.avengers = [];

activate();

function activate() {

return getAvengers().then(function() {

logger.info('Activated Avengers View');

});

}

function getAvengers() {

return dataService.getAvengers()

.then(function(data) {

vm.avengers = data;

return vm.avengers;

});

}

}

/*

Data操作全部用Service

* 抽出data操作, 例如:http, local storage, db都纳入service中, (不要放在controller中)

* 返回promise, 以利于chain操作

*/

// 对于controller和service

AvengersController.$inject = ['moviesPrepService'];

// 对于 route

function config($routeProvider) {

$routeProvider

.when('/avengers', {

templateUrl: 'avengers.html',

controller: 'AvengersController',

controllerAs: 'vm',

resolve: {

moviesPrepService: moviesPrepService

}

});

}

moviesPrepService.$inject = ['movieService'];

function moviesPrepService(movieService) {

return movieService.getMovies();

}

/*

Manual Annotating for Dependency Injection: 手工注入, 让minify安全

*/

/*

其余主题:

Minification and Annotation: 注释,适合minify的

Exception Handling

*/

/* Naming: 命名规范

featureType.js

*/

用几个代码段, 和 简要的 原则注释, 来直观地展示编程好习惯。

angularjs1,2的
js的
dom的
类和子类的
module的

https://github.com/johnpapa/angular-styleguide/blob/master/a1/README.md
https://github.com/johnpapa/angular-styleguide/blob/master/i18n/zh-CN.md

Best Practice AngularJS的更多相关文章

  1. angularJS学习资源最全汇总

    基础 官方: http://docs.angularjs.org angularjs官方网站已被墙,可看 http://www.ngnice.com/: 官方zip下载包 https://github ...

  2. AngularJS Providers 详解

    供应者(Providers) Each web application you build is composed of objects that collaborate to get stuff d ...

  3. 【转】Build Your own Simplified AngularJS in 200 Lines of JavaScript

    原文:http://blog.mgechev.com/2015/03/09/build-learn-your-own-light-lightweight-angularjs/ Build Your o ...

  4. AngularJS中实现服务端分页

    这个教程将介绍在AngularJS应用中的服务端分页处理.在任何涉及到列表或表格数据的应用中都可能会用到分页. 概念 当我们处理异步分页时,每次只从服务器上获取一页数据.也就是说当用户点击第二页,就只 ...

  5. [AngularJS] Angular 1.3 Anuglar hint

    Read More: http://www.linkplugapp.com/a/953215 https://docs.google.com/document/d/1XXMvReO8-Awi1EZXA ...

  6. angularJS web应用SEO

    javascript给网站带来丰富的用户体验,越来越多的网站开始应用angularjs/emberjs这类MVC来开发web应用,可以说能够使用native方式来看法的手机app基本都可以使用替代的j ...

  7. AngularJS入门之如何快速上手

      概述: AngularJS(ng)是一个纯JS框架,AngularJS易于构建CRUD应用(CRUD意思是增删改查) 适用于以数据操作为主的SPA(Single Page Application) ...

  8. ANGULARJS: UNDERSTANDING DIRECTIVE SCOPE

    https://www.3pillarglobal.com/insights/angularjs-understanding-directive-scope --------------------- ...

  9. 通过AngularJS实现前端与后台的数据对接(二)——服务(service,$http)篇

    什么是服务? 服务提供了一种能在应用的整个生命周期内保持数据的方法,它能够在控制器之间进行通信,并且能保证数据的一致性. 服务是一个单例对象,在每个应用中只会被实例化一次(被$injector实例化) ...

随机推荐

  1. ML(4)——逻辑回归

    Logistic Regression虽然名字里带“回归”,但是它实际上是一种分类方法,“逻辑”是Logistic的音译,和真正的逻辑没有任何关系. 模型 线性模型 由于逻辑回归是一种分类方法,所以我 ...

  2. kafka 知识点

    Replica如何分布 为了尽量做好负载均衡和容错能力,需要将同一个Partition的Replica尽量分散到不同的机器.如果所有的Replica都在同一个Broker上,那一旦该Broker宕机, ...

  3. 安装mysql时包冲突解决方法

    报错信息如下: 解决办法: 在卸载代码上加上不检查关联信息即可(rpm -ev mysql-libs-5.1.73-7.el6.x86_64 --nodeps) 检查服务器是否还有mysql安装包:r ...

  4. Zookeeper 三台主机 Ha集群的搭建

    前期准备1.修改Linux主机名 2.修改IP 3.修改主机名和IP的映射关系 /etc/hosts ######注意######如果你们公司是租用的服务器或是使用的云主机(如华为用主机.阿里云主机等 ...

  5. C#:memcached安装及.NET中的Memcached.ClientLibrary使用详解

    memcached分布式缓存的负载均衡配置比例,数据压缩,socket的详细配置等,以及在.net中的常用方法. 下载地址:http://pan.baidu.com/s/1yVILw       提取 ...

  6. 读取配置文件的C语言接口实现

    在一些场合,需要对一些配置文件进行读取,去设置软件的参数,自己实现了一些接口函数,以供以后使用. ConfigFile.c #include <stdio.h> #include < ...

  7. 把指定的字符串翻译成 pig latin。

    freecodecamp上的算法题: 把指定的字符串翻译成 pig latin. Pig Latin 把一个英文单词的第一个辅音或辅音丛(consonant cluster)移到词尾,然后加上后缀 & ...

  8. django get post files请求知识点

    GET: 我们在浏览器里直接键入地址回车,这种方式其实也是get方式提交了数据,如: http://localhost/login?user=123&pwd=123  就是把用户名123密码1 ...

  9. docker-compose网络设置之networks

    networks使用方式之官网教程 官网的docker-compose.yml参考文档:Compose file version 3 reference 较为准确的中文翻译版:Compose file ...

  10. oracle sql 添加、修改数据库操作方式

    年龄大了,写程序总记不住.记录一下格式: private const string SQL_INSTERT = @"INSERT INTO QS_ROOM_QUEUE (QUEUEID,RO ...