js024-最佳实践

本章内容:

可维护的代码

保证代码性能

部署代码

24.1 可维护性

24.1.1 代码的可维护性

代码可维护性的特征:

特性

说明

可理解性

其他人可以理解它的用途和一般途径

直观性

代码中的东西能一看就明白,不论其操作过程多么复杂

可适应性

代码以一种数据上的变化不要求完全重写的方法撰写

可扩展性

在代码架构上已考虑到在未来允许对核心功能进行扩展。

可调试性

当有地方出错时,代码可以给予你足够的信息来尽可能直接的确定问题所在。

 

24.1.2 代码约定

1、可读性

在必要的地方进行必要的注释

A、函数和方法

B、 大段代码

C、 复杂的算法

D、Hack

2、变量个函数名

变量名应为名词

函数名应以动词开始,返回布尔类型的一般以is开始

变量和函数都应使用合乎逻辑的名字

3、变量类型透明

有3种表示数据类型的方式:

A、初始化;

B、 使用匈牙利标记法来指定变量信息

C、 使用类型注释

24.1.3 松散耦合

1、HTML/JavaScript

2、CSS/JavaScript

3、应用逻辑/事件处理程序

24.1.4 编程实践

1、尊重对象所有权

不要为实例或原型添加属性;

不要为实例或原型添加方法;

不要重定义已存在的方法;

2、避免全局量

3、避免与null进行比较

如果看到了与null比较的代码金陵尝试一下技术替换:

A.如果值应为一个引用类型,使用instanceof操作符检查其构造函数;

B. 如果值应为一个基本类型,使用typeof操作符检查其类型;

C. 如果是希望对象包含某个特定的方法名,则使用typeof操作符确保指定名字的方法存在于对象上。

!!代码中的null比较越少,就越容易确定代码的目的,并消除不必要的错误。

4、使用常量

将数据和使用它的逻辑进行分离:

A、重复值:任何在多处用到的值,都应该抽取为一个常量。(这样容易造成当一个值变了另一个值没变的错误);

B、 用户界面字符串:任何用于显示给用户的字符串,都应该抽取出来以方便国际化;

C、 URLs:在web中,资源位置很容易变更,所以推荐用一个公共地方存放所有的URL;

D、任意可能会更改的值:每当你用字面量的时候,都应该考虑该变量的值是否不会再改变,如果是的话,这个值应该被提取出来作为一个常量

24.2 性能

24.2.1 注意作用域

1、避免全局查找

2、避免with语句

24.2.2 选择正确的方法

1、避免不必要的属性查找

2、优化循环

A、减值迭代

B、简化终止条件

C、简化循环体

D、使用后测试循环:for和while是前测试循环,do-while是后测试循环,可以避免最初终止条件的计算,因此运行更快。

3、展开循环

4、避免双重解释

5、性能的其他注意事项

A、原生方法比较快

B、Switch语句比较快

C、位运算符比较快

24.2.3 最小化语句数

1、多个变量生命

2、插入迭代值

3、使用数组和对象字面量

24.2.4 优化DOM交互

1、最小化现场更新

2、使用innerHTML

3、使用事件代理

4、注意HTMLCollection

24.3 部署

24.3.1 构建过程

注意:

1、知识产权问题;

2、文件大小;

3、代码组织

24.3.2 验证

24.3.3 压缩

1、文件压缩

压缩器一般进行如下步骤:

A.删除二外的空白(包括换行)

B. 删除所有的注释

C. 缩短变量名

2、HTTP压缩

声明:该博客由http://www.cnblogs.com/lal-fighting/原创发表,未经作者允许,不得私自转载抄袭!!!

js024-最佳实践的更多相关文章

  1. ASP.NET跨平台最佳实践

    前言 八年的坚持敌不过领导的固执,最终还是不得不阔别已经成为我第二语言的C#,转战Java阵营.有过短暂的失落和迷茫,但技术转型真的没有想象中那么难.回头审视,其实单从语言本身来看,C#确实比Java ...

  2. 《AngularJS深度剖析与最佳实践》简介

    由于年末将至,前阵子一直忙于工作的事务,不得已暂停了微信订阅号的更新,我将会在后续的时间里尽快的继续为大家推送更多的博文.毕竟一个人的力量微薄,精力有限,希望大家能理解,仍然能一如既往的关注和支持sh ...

  3. ASP.NET MVC防范CSRF最佳实践

    XSS与CSRF 哈哈,有点标题党,但我保证这篇文章跟别的不太一样. 我认为,网站安全的基础有三块: 防范中间人攻击 防范XSS 防范CSRF 注意,我讲的是基础,如果更高级点的话可以考虑防范机器人刷 ...

  4. 快速web开发中的前后端框架选型最佳实践

    这个最佳实践是我目前人在做的一个站点,主要功能: oauth登录 发布文章(我称为"片段"),片段可以自定义一些和内容有关的指标,如“文中人物:12”.支持自定义排版.插图.建立相 ...

  5. Spring Batch在大型企业中的最佳实践

    在大型企业中,由于业务复杂.数据量大.数据格式不同.数据交互格式繁杂,并非所有的操作都能通过交互界面进行处理.而有一些操作需要定期读取大批量的数据,然后进行一系列的后续处理.这样的过程就是" ...

  6. Atitit.log日志技术的最佳实践attilax总结

    Atitit.log日志技术的最佳实践attilax总结 1. 日志的意义与作用1 1.1. 日志系统是一种不可或缺的单元测试,跟踪调试工具1 2. 俩种实现[1]日志系统作为一种服务进程存在 [2] ...

  7. PHP核心技术与最佳实践——全局浏览

    难得买到并喜欢一本好书,‘PHP核心技术与最佳实践’. 几天时间,先看了个大概,总结一下整体是什么样子的,怎么看怎么学. 1.总共14章: 2.第1.2章讲PHP的OOP: 其中第一章侧重于PHP的O ...

  8. Abp集成Swagger的最佳实践

    1.在项目中添加nuget包 Abp.Web.Api.SwaggerTool 2.在项目Abp模块的DependsOn添加AbpWebApiSwaggerToolModule Run It,启动项目, ...

  9. MySQL · 答疑解惑 · MySQL 锁问题最佳实践

    http://mysql.taobao.org/monthly/2016/03/10/ 前言 最近一段时间处理了较多锁的问题,包括锁等待导致业务连接堆积或超时,死锁导致业务失败等,这类问题对业务可能会 ...

  10. 《转载》Java异常处理的10个最佳实践

    本文转载自 ImportNew - 挖坑的张师傅 异常处理在编写健壮的 Java 应用中扮演着非常重要的角色.异常处理并不是功能性需求,它需要优雅地处理任何错误情况,比如资源不可用.非法的输入.nul ...

随机推荐

  1. Jmeter测试工具使用

    启动Jmeter: 路径:\apache-jmeter-2.13\bin\jmeter.bat 一.测试Http请求: 建立过程: 1.  测试计划--添加---Threads--线程组 2.  线程 ...

  2. 委托(delegate)

    委托(dekegate)是一种动态调用方法的类型,与类.接口和数组相同,属于引用型,可以用来实现多路广播(MulticastDelegate). 多路广播(MulticastDelegate):可以用 ...

  3. myeclipse下java文件乱码问题解决

    中文乱码是因为编码格式不一致导致的.1.进入Eclipse,导入一个项目工程,如果项目文件的编码与你的工具编码不一致,将会造成乱码.2.如果要使插件开发应用能有更好的国际化支持,能够最大程度的支持中文 ...

  4. jQuery总结(2016-7-4)

    1.事件对应有事件的方法, 如click事件, 有click()方法. 2.jQuery动画 3.AJAX是与服务器交换数据的技术! load()方法     get()方法    post()方法

  5. lineNumber: 1; columnNumber: 1; 前言中不允许有内容

    周六项目还能运行,也没修改什么,周一来了启动项目,竟然报错了~~~ 这是遇到的错误提示: Cause: org.xml.sax.SAXParseException; lineNumber: 1; co ...

  6. 【CodeVS 3290】【NOIP 2013】华容道

    http://codevs.cn/problem/3290/ 据说2013年的noip非常难,但Purpleslz学长还是AK了.能A掉这道题真心orz. 设状态$(i,j,k)$表示目标棋子在$(i ...

  7. 【BZOJ 3165】【HEOI 2013】Segment

    往区间上覆盖一次函数,做法是用线段树维护标记永久化. 每次都忘了线段树要4倍空间,第一次交总是RE,再这么手残的话考场上就真的要犯逗了. #include<cstdio> #include ...

  8. dede使用方法---如何添加视频

    根据客户的需求,需要上传客户自己的视频,但是发现一个视频就有一百多M,想到数据库总共可容纳的才一百多M,于是想到利用其他专业的视频网站,再嵌入到自己的网站里面. 我在这里选的是爱奇艺,下面总结一下主要 ...

  9. 【BZOJ-1090】字符串折叠 区间DP + Hash

    1090: [SCOI2003]字符串折叠 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1127  Solved: 737[Submit][Stat ...

  10. linux下命令运行目录上程序前面要加./

    linux命令行上默认运行path系统变量的路径的程序,所以我们在运行时命令时会在系统变量中查找,而发现查找完系统变量之后是不会再查找当前目录的. 有以下方式解决: 1.在运行当前目录的程序时,前面加 ...