「转」你必须学会编写优秀的 JS 代码之编程习惯

引言

一图胜千言,给大家先看一张代码量的对比图:

代码量随时间的变化

得出结论:

  • 糟糕的代码设计会让我们在前期写很少的代码,就能实现很多需求,但是后期,代码量随时间的变化会发生指数级的增长,我们将会有很繁重的任务。
  • 优秀的代码设计会让我们在前期做很多的操作,但是后期的时候,只需要很少的代码就能实现需求,代码量增长的速度也会很慢,我们会有很多的空闲时间做自己喜欢的事。

所以,我相信不会有人喜欢做繁重的任务,为了写出优秀的代码,我们除了要养成良好的编程习惯外,还要不断的去学习更优秀的代码结构和编程方式。

在分享自己的技术经验之前,先告诉大家,我不会写诸如 缩进层级,行的长度,换行空行,注释,文档注释,花括号对齐方式 等方面的规范,不是因为它们不重要,而是因为这不是决定代码质量的核心因素,而且没有统一规范,各大公司采用的标准都有差异,所以这些因素不在本篇文章的范围内,如果大家需要,我会在后期文章中专门写一篇关于这些规范的文章,有需要的请私信我。

进入正题

我会从 2 个方面(编程习惯,代码结构)来概述 。

编程习惯

  • 异常处理
    如果你没有使用异常处理的习惯,这可能是因为你并未真正的理解它的作用。当你正确使用异常处理之后,你会发现你的代码最显著的变化就是:少了 很多的 if-else 语句 。虽然在 JS 中,只有错误(Error),没有异常(Exception),但是我们很多人还是喜欢将之成为异常( 我觉得并没什么不好,反而 会更形象),js 把 异常分为以下6种:

    EvalError: raised when an error occurs executing code in eval()
    RangeError: raised when a numeric variable or parameter is outside of its valid range
    ReferenceError: raised when de-referencing an invalid reference
    SyntaxError: raised when a syntax error occurs while parsing code in eval()
    TypeError: raised when a variable or parameter is not a valid type
    URIError: raised when encodeURI() or decodeURI() are passed invalid parameters

    但是很多人都以为只能使用这6种异常,不符合项目中的需求,所以就不使用异常处理了,但其实我们完全可以根据自己的项目去自定义一些异常,我建议大家在错误消息中包含函数名称以及失败的原因,这样会十分利于你的代码调试,如图:

    自定义异常处理

    为了便于统一管理,我建议大家自己建立一个异常模块,需要的时候,直接引入这个模块,如图:

异常模块

大家如果不习惯使用 异常处理 的话,我的建议是从你的下一个项目开始,你就试着去用异常处理,你会发现你的代码非常优雅,省去很多的 if-else,十分干净利落。

  • 事件处理

    有经验的开发者一定会知道,随着项目内容增多的时候,代码里面的事件处理程序会特别多,如果没有良好的管理,应用逻辑会和事件处理程序紧密的耦合在一起,而且这时的代码会有很大的冗余。为了解决这种问题,我建议大家采用以下3个方法:

    1. 隔离应用逻辑:将应用逻辑从所有事件处理程序中抽离出来是最佳的方法,因为你不知道接下来什么时候还会触发同一段的逻辑。
    隔离应用逻辑
    1. 禁止分发对象:既然应用逻辑和事件处理程序是完全隔离的,那么应用程序中就不能有任何与事件有关的代码,所以,应用逻辑不能依赖于 event 对象来实现某一功能。
    禁止分发对象
    1. 定义事件注册模块:整个时代都在提倡 js 代码统一模块化管理,所以,为了方便管理,我们有必要定义一个事件注册模块,用来统一完成事件的注册( 绑定 ) 和 移除
    事件注册模块
  • 配置分离
    每一次修改源代码,都会有引入 bug 的风险,且只修改一些数据也会带来许多意外的风险,因为数据是不影响指令正常运行的,精心设计的应用应该把关键数据从源码中抽离出来,这样,我们每次修改时,只需要修改抽离出的那部分代码就行了,这样既简单方便又降低了很多风险。什么是配置数据呢?就是在应用中写死了的那些值,如图的代码:

    "/write.php"就是配置数据

    "/write.php"就是配置数据,想象一下,这只是一个文件中的代码,如果有100个文件中有这样的代码,假设某天,网站的 write.php 改成了 compose.php ,那么你就要将 "/write.php" 改100次 ! 所以,无论是从安全上讲还是从可维护上讲,我们都很有必要抽离出配置项,并且定义在 Config 配置模块中。(需要自己自定义一个 Config 配置模块,代码就不用演示了吧。。。)

  • 其他

    1. 将 CSS 代码从 JS 代码中抽离出来(推荐 使用 class 类名作为 CSS 和 JS 通信的桥梁)
    2. 将 JS 代码从 HTML 标签中分里出来( 不要使用<span onclick="dosomething()" ></span>)。
    3. 将 HTML 从 JS 中抽离出来 。这里特别说一下,有些人可能会习惯了在 JS 代码中 这样写:$( "p" ).append( '<h2>大家好</h2>' ),这样并不是不可行,但是当需要插入大量的 HTML 标签时,代码就会变得十分丑陋而且难以维护,我们可以使用以下方法来解决这个问题:
    • 使用 Jquery 的 load( "路径" ) 方法 从服务端加载 。
    • 使用<script type="text/html"> 在这里书写你的 HTML 代码 </script>

结束

我突然发现本篇内容写的有点多了,所以 “代码结构” 这部分只能留到下一篇文章再讲了,我担心文章太长会让人没有耐心 ,其实就连本篇,我都感觉很多东西还没讲,但是因为长度原因,只能先搁置了。再说一下,下一篇文章,我再将本篇没有讲的 “代码结构” 部分好好讲一讲。

有什么地方不完善,出错,或者是漏掉的,请大家给我留言,私信,我会及时修改的。在编程的道路上,希望大家都坚持下去,加油,共勉!!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,650评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,052评论 25 707
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,802评论 6 342
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,951评论 6 13
  • SVG描边动画,使用了SVG图形中PATH标签的stroke特性制作的动画。 为什么使用SVG? 相对于其他的图片...
    晴_feng阅读 1,167评论 0 1