1. 不要重置对象的引用!(重置只应该在组件或服务的初始化时) why:会使页面产生闪烁
  2. 不要给图片绑定一个空的值或空的图片引用(如果值从服务器异步过来,那应该在初始化时给它一个默认值)why:会触发一个404的请求 (如:img src=http://xxxx/null)
  3. 页面全部使用最新的angular2写法,on-click=>(click) bind-src=>[src] bind-html=>[innerHtml]

规范:

  • 拆分模型和控制器(保持“瘦”控制器,“胖”模型的原则【界面交互在控制器里,业务逻辑都封装在模型里】)

代码写法技巧:

  • if else 嵌套最多两级,减少代码逻辑层级【优化阅读】。  
    例子:

            queryCard.success = function (data) {
    console.log(data);
    that.pageInfo.bindCardList = JSON.parse(data);
    if (that.pageInfo.bindCardList == null || that.pageInfo.bindCardList.length <= 0) {
    that.viewInfo.isbindedCard = false;
    }
    else {
    that.viewInfo.isbindedCard = true;
    for (let entry of that.pageInfo.bindCardList) {
    var cardStr = entry.card_no.split(' ').join('');
    if (cardStr.length != 20 && cardStr.length != 13) {
    continue;
    } if (cardStr.length == 20) {
    entry.card_no = cardStr.substr(0, 5) + " " + cardStr.substr(5, 5) + " " + cardStr.substr(10, 5) + " " + cardStr.substr(15, 5);
    } else {
    entry.card_no = cardStr.substr(0, 5) + " " + cardStr.substr(5, 5) + " " + cardStr.substr(10, 3);
    }
    //构造弹窗信息
    if (entry.is_default == 0) {
    entry["isSelect"] = 0;
    that.pageInfo.inputCardNo = entry.card_no;
    that.getCardLLInfo();
    } else {
    entry["isSelect"] = 1;
    }
    }
    }
    };

    =>

    queryCard.success = function (data) {
    console.log(data);
    that.pageInfo.bindCardList = JSON.parse(data);
    if (that.pageInfo.bindCardList == null || that.pageInfo.bindCardList.length <= 0) {
    that.viewInfo.isbindedCard = false;
    return;
    }
    that.viewInfo.isbindedCard = true;
    for (let entry of that.pageInfo.bindCardList) {
    var cardStr = entry.card_no.replace(" ",""); // <= split(' ').join(''); 其实应该把没有空格的值单独保存,很多地方都在使用它
    if (cardStr.length != 20 && cardStr.length != 13) {
    continue;
    }
    ......

      

  • 尽量杜绝常量的使用【优化阅读】
    例子:
    <button *ngIf="item.activity_status == " class="btn btn-locate baidu" opt="N-去领取"
    =>

    <button *ngIf="item.activity_status == PKGActivityStatus.normal" class="btn btn-locate baidu" opt="N-去领取"
  • 变量和函数命名清晰,不含糊或生僻(不用太在意名字长度,如果含义清楚,可以接收)
  • 尽量消除重复代码(又在埋坑)
    如: entry.card_no.split(' ').join('');  或者  cookieService.get("abc");
  • 没用的代码、变量尽早删除
  • 冗余的代码必须精简:

    直接改写成:

        isShowCardListAlert() {
    return !this.viewInfo.isShowCardList
    }

    简化之后,发现,连这个函数都是冗余的:

    再分析,发现连变量【viewInfo.isShowCardList】都是多余的:

    <div class="win-box align-center" [hidden]="true" #winBox>
    <div class="bottom-box">
    <div class="tc-title"><span>切换其他卡</span><span class="close-plan" (click)="winBox.hidden=false">关闭</span></div>
    <div *ngFor="let item of pageInfo.bindCardList">
    ......

    最终控制器代码省掉了一个变量的操作,一整块儿函数!  

  • 定义对象的属性 entry["isSelect"] = 0 改成 entry.isSelect = 0
    还有 

    为什么要用“双引号”,这样连智能感知都被屏蔽了!而且审核代码的人,无法看出你到底是哪个字母写错了,还是多了个空格(巨坑!这个不仅仅是js代码的问题

  • 写代码时,请多为接手你代码的人想想!这种代码(已经无法表达此时的感受):

       =》 

    这段代码.......(不想说话)  还有下面这个:

    请尽量消除重复!!消除重复!消除重复!

  • 为了删除一个
    activity.warningCount 我必须小心翼翼,不知道哪里在使用,不知道,它用来干什么?!
  •  

Angular2 前端代码规范的更多相关文章

  1. Web 前端代码规范

    Web 前端代码规范 最后更新时间:2017-06-25 原始文章链接:https://github.com/bxm0927/web-code-standards 此项目用于记录规范的.高可维护性的前 ...

  2. eslint+prettier+husky+lint-staged 统一前端代码规范

    eslint+prettier+husky+lint-staged 统一前端代码规范 遵循编码规范和使用语法检测,可以很好的提高代码的可读性,可维护性,并有效的减少一些编码错误. 1.终极目标 团队中 ...

  3. idataway_前端代码规范

    1.前后端json对接的规范. 前后端的json代码规范 result ={ success:”true”,//true表示成功,false表示失败. data:{}, //数据 errorCode: ...

  4. Web前端代码规范

    新增:http://materliu.github.io/code-guide/#project-naming HTML 原则1.规范 .保证您的代码规范,保证结构表现行为相互分离.2.简洁.保证代码 ...

  5. Web前端代码规范与页面布局

    一.    规范目的: 为提高工作效率,便于后台人员添加功能及前端后期优化维护,输出高质量的文档,在网站建设中,使结构更加清晰,代码简明有序,有一个更好的前端架构,有利于SEO优化.   二.     ...

  6. web前端代码规范——css代码规范

    Bootstrap CSS编码规范 语法 用两个空格来代替制表符(tab) -- 这是唯一能保证在所有环境下获得一致展现的方法. 为选择器分组时,将单独的选择器单独放在一行. 为了代码的易读性,在每个 ...

  7. web前端代码规范 - HTML代码规范

    Bootstrap HTML编码规范 本文转载自w3cschool. 由于bootstrap得到了世界的认可,因此,此规范用于规范html代码有一定的说服力. 交流qq群:164858883.欢迎各位 ...

  8. 腾讯alloyteam团队前端代码规范

    来源于:http://alloyteam.github.io/CodeGuide/ 命名规则 项目命名 全部采用小写方式, 以下划线分隔. 例:my_project_name 目录命名 参照项目命名规 ...

  9. 前端代码规范-Javascript

    命名规范 ECMAScript 规范中标识符采用驼峰大小写格式,驼峰命名法由小(大)写字母开始,后续每个单词首字母都大写.根据首字母是否大写,分为两种方式: Pascal Case 大驼峰式命名法:首 ...

随机推荐

  1. apache2 + django

    参照: http://blog.topspeedsnail.com/archives/7828 注意,当django安装在虚拟环境下时,配置文件里面需要有python-home 指向虚拟环境 WSGI ...

  2. git 学习之基础知识

    在前面的一个帖子中我们知道了不同的版本控制系统的不同,在这个帖子中我们会大致的了解到它们是管理各个版本的,这对我们学习 git 是很有帮助的. 对于集中式的版本控制系统来说每次的更新主要记录内容的具体 ...

  3. Python基础(3) - 数据类型:3列表类型

    Python 列表是序列对象,可包含任意的Python数据信息,如字符串.数字.列表.元组等.列表的数据是可变的,我们可通过对象方法对列表中的数据进行增加.修改.删除等操作.列表用[]包括起来的. 列 ...

  4. C语言入门语法

    一.数据类型 常量 1.通过预处理声明常量 #include <stdio.h> #define PRICE 100 int main() { printf("价格:%d\n&q ...

  5. Git中.gitignore, 忽略追踪

    在目录下 创建: .gitignore文件,将不需要被追踪的文件地址, 写在该文件中, 此时git软件就不会追踪列出的文件进行版本同步: windows不允许创建没有文件名的文件,可以用编辑器创建.g ...

  6. WAMP环境配置-Apache服务器的安装

    一.下载 下载地址:http://httpd.apache.org/ 在这里就可以下载想下载的版本了 二.安装 我这次环境配置安装的是Apache-2.4.23版本! (最近我在反复安装PHP的时候出 ...

  7. [转] 多种方法查看Oracle SQL执行计划

    本文转自:http://falchion.iteye.com/blog/616234 一.在线查看执行计划表 如果PLAN_TABLE表不存在,执行$ORACLE_HOME/rdbms/admin/u ...

  8. JS实现队列

    JS实现队列: 队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表.进行插入操作的端称为队尾 ...

  9. MongoDb 学习笔记(一) --- MongoDb 数据库介绍、安装、使用

    1.数据库和文件的主要区别 . 数据库有数据库表.行和列的概念,让我们存储操作数据更方便 . 数据库提供了非常方便的接口,可以让 nodejs.php java .net 很方便的实现增加修改删除功能 ...

  10. linux系统下部署项目

    一.修改防火墙设置,开放对应的端口 修改Linux系统防火墙配置需要修改 /etc/sysconfig/iptables 这个文件,如果要开放哪个端口,在里面添加一条  -A RH-Firewall- ...