iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >教你如何写出可维护的JS代码
  • 297
分享到

教你如何写出可维护的JS代码

2024-04-02 19:04:59 297人浏览 泡泡鱼
摘要

目录什么是可维护代码代码约定1.可读性2.变量和函数的命名3.变量类型透明松散耦合1.解耦html/javascript2.解耦CSS/JavaScript3.解耦应用逻辑/事件处理

什么是可维护代码

可维护代码需要遵循以下几个特点。

1.可理解性-其他人可以接手代码并理解它的意图和一般途径。
2.直观性-代码中的东西一看就明白,不管其操作过程有多复杂。
3.可适应性-代码以一种数据变化不要求完全重写的方法撰写。
4.可扩展性-在代码架构上已考虑在未来允许对核心功能进行扩展。
5.可调试性-当有地方出错时,代码可以给你足够的信息快速直接找出问题的所在。

代码约定

一种让代码变得可维护的简单途径是形成一套JavaScript代码的书写约定。由于JavaScript的可适应性,代码约定对它很重要。以下小节讨论代码约定的概论。

1.可读性

要让代码可维护,首先它必须可读。可读性的大部分内容和代码缩进相关的,代码整齐的缩进能一眼看出代码块是属于那个功能的,很常见的缩进大小为4个空格,现在大部分编辑器也支持一件格式化代码。可读性另一方面是注释,一般来说,有如下一些地方需要进行注释。

  • 函数和方法-每个方法或注释都应该包含一个注释,用于描述其目的和用于完成任务所可能使用的算法
  • 大段代码-用于完成单个任务的多行代码应该在前面放一个描述任务的注释。
  • 复杂的算法-使用独特的方式来解决某个问题加以注释来解释如何做的。
  • Hack-浏览器兼容性处理。

2.变量和函数的命名

话说在平时开发中最让人头疼的事莫过于命名了,无论是class的命名还是一些变量与方法的命名,所以有时候不得不靠一些翻译软件来帮助命名。适当给变量和函数起名字对于增加代码的可理解性和可维护性是非常重要的。命名规则一般如下:

  • 变量名应为名词如car或person。
  • 函数名应以动词开始,如getName()。
  • 返回布尔类型的函数一般用is开头,如isEnable()。
  • 常量应该用全部大写表示,如MAX_LENGTH。

3.变量类型透明

由于在JavaScript中变量是松散类型的,很容易忘记变量所包含的数据类型。合适的命名方式在一定程度上可以缓解这个问题,但是放到所有的情况下看还不够,还有三种变量数据来表示数据类型的方式。

3.3.1、初始化

当定义一个变量后,它应该被初始化一个值,来暗示它将来应该如何应用。


// 通过初始化指定变量类型
var found=false; //布尔型
var count=-1; //数字型
var name=""; //字符串
var person=null; //对象

3.3.2、使用匈牙利标记法指定变量类型

匈牙利标记法在变量名之前加上一个或多个字符来表示数据类型。js中最传统的匈牙利标记法是用单个字符来表示基本类型:0-对象,s-字符串,i-整数,f-浮点数,b-布尔类型。


// 用于指定数据类型的匈牙利命名法
var bFound //布尔型
var iCount; //数字型
var sName; //字符串
var oPerson; //对象

匈牙利命名法好处是函数参数也一样可以使用,但它缺点是让代码在某种程度上那一阅读。

3.3.3、使用类型注释

最后一种指定变量类型的方式是使用类型注释。类型注释放在变量名右边,但是在初始化前面。


// 用于指定类型的类型注释
var found  = false;
var count  = 10;
var name  = "Tom";
var person  = null;

缺点:多行注释会与代码块冲突

这三种常见的指定变量数据类型的方法,各有优势与劣势,根据自己项目加以评估再进行使用,也可以学习使用下typescript

松散耦合

只要应用的某个部分过分依赖另一部分,代码就是偶尔过紧,难以维护。因为WEB应用技术,有多种情况回使它变得耦合过紧,因此应该避免这些情况,并尽可能维护弱耦合代码。

1.解耦html/JavaScript

直接在html中的javaScript,使用包含内联代码的<script>元素或者是使用HTML属性来分配事件处理顺序,都是过于紧密耦合。

看看以下的代码


<button onclick="doSomeThing()">Click Me</button>

在这个例子中,可能在doSomeThing()函数可用之前,就已经按下按钮,导致js错误,因为任何对按钮行为的更改要同时触及HTML和js,影响可维护性。

同理js中包含大量的HTML


// 将HTML紧密耦合到js中
function insertMessage(){
  document.getElementById('container').innerHTML='<div>Hello World</div>'
}

这段代码的方法会动态生成一段代码块插入到页面中,当代码很多时候难以定位到错误。

将 HTML 和 JavaScript 解耦可以在调试过程中节省时间,更加容易确定错误的来源,也减轻维护的难度:更改行为只需要在 JavaScript 文件中进行,而更改标记则只要在渲染文件中

2.解耦css/JavaScript

另一个 Web 层则是css,它主要负责页面的显示。JavaScript 和 CSS 也是非常紧密相关的:他们都是 HTML 之上的层次,因此常常一起使用。但是,和 HTML 与 JavaScript 的情况一样,CSS 和 JavaScript也可能会过于紧密地耦合在一起。最常见的紧密耦合的例子是使用 JavaScript 来更改某些样式,如下所示:


//CSS 对 JavaScript 的紧密耦合
element.style.color = "red"; 
element.style.backgroundColor = "blue";

遇到这种直接修改css样式的,我们直接可以通过修改元素标签class类名来控制样式更方便。

3.解耦应用逻辑/事件处理程序

每个 Web 应用一般都有相当多的事件处理程序,监听着无数不同的事件。然而,很少有能仔细得将应用逻辑从事件处理程序中分离的。请看以下例子:


function handleKeyPress(event) {
        event = EventUtil.getEvent(event);
        if (event.keyCode == 13) {
            var target = EventUtil.getTarget(event);
            var value = 5 * parseInt(target.value);
            if (value > 10) {
                document.getElementById("error-msg").style.display = "block";
            }
        }
    }

这个事件处理程序除了包含了应用逻辑,还进行了事件的处理。这种方式的问题有其双重性。首先,除了通过事件之外就再没有方法执行应用逻辑,这让调试变得困难。如果没有发生预想的结果怎么办?是不是表示事件处理程序没有被调用还是指应用逻辑失败?其次,如果一个后续的事件引发同样的应用逻辑,那就必须复制功能代码或者将代码抽取到一个单独的函数中。无论何种方式,都要作比实际所需更多的改动。

较好的方法是将应用逻辑和事件处理程序相分离,这样两者分别处理各自的东西。一个事件处理程序应该从事件对象中提取相关信息,并将这些信息传送到处理应用逻辑的某个方法中。例如,前面的代码可以被重写为:


 function validateValue(value) {
        value = 5 * parseInt(value);
        if (value > 10) {
            document.getElementById("error-msg").style.display = "block";
        }
    }

    function handleKeyPress(event) {
        event = EventUtil.getEvent(event);
        if (event.keyCode == 13) {
            var target = EventUtil.getTarget(event);
            validateValue(target.value);
        }
    }

应用和业务逻辑之间松散耦合的几条原则:

  • 勿将 event 对象传给其他方法;只传来自 event 对象中所需的数据;
  • 任何可以在应用层面的动作都应该可以在不执行任何事件处理程序的情况下进行;
  • 任何事件处理程序都应该处理事件,然后将处理转交给应用逻辑。

牢记这几条可以在任何代码中都获得极大的可维护性的改进,并且为进一步的测试和开发制造了很多可能。

编程实践

书写可维护的 JavaScript 并不仅仅是关于如何格式化代码;它还关系到代码做什么的问题。在企业环境中创建的 Web 应用往往同时由大量人员一同创作。这种情况下的目标是确保每个人所使用的浏览器环境都有一致和不变的规则。因此,最好坚持以下一些编程实践。

1.尊重对象所有权

JavaScript 的动态性质使得几乎任何东西在任何时间都可以修改。也许在企业环境中最重要的编程实践就是尊重对象所有权,它的意思是你不能修改不属于你的对象。简单地说,如果你不负责创建或维护某个对象、它的对象或者它的方法,那么你就不能对它们进行修改。更具体地说:

  • 不要为实例或原型添加属性;
  • 不要为实例或原型添加方法;
  • 不要重定义已存在的方法。

2.避免全局变量

与尊重对象所有权密切相关的是尽可能避免全局变量和函数。这也关系到创建一个脚本执行的一致的和可维护的环境。最多创建一个全局变量,让其他对象和函数存在其中。请看以下例子:


// 两个全局量——避免!!
var name = "Nicholas"; 
function sayName(){ 
 alert(name); 
} 

这段代码包含了两个全局量:变量 name 和函数 sayName()。其实可以创建一个包含两者的对象,如下例所示:


// 一个全局量——推荐
var MyApplication = { 
 name: "Nicholas", 
 sayName: function(){ 
 alert(this.name); 
 } 
}; 

这段重写的代码引入了一个单一的全局对象 MyApplication,name 和 sayName()都附加到其上。这样做消除了一些存在于前一段代码中的一些问题。首先,变量 name 覆盖了 window.name 属性,可能会与其他功能产生冲突;其次,它有助消除功能作用域之间的混淆。调用 MyApplication.sayName()在逻辑上暗示了代码的任何问题都可以通过检查定义 MyApplication 的代码来确定。

3.使用常量

以下一些类型的值适合使用常量来定义:

  • 重复值——任何在多处用到的值都应抽取为一个常量。这就限制了当一个值变了而另一个没变的时候会造成的错误。这也包含了 CSS 类名。
  • 用户界面字符串 —— 任何用于显示给用户的字符串,都应被抽取出来以方便国际化。
  • URLs ——在 Web 应用中,资源位置很容易变更,所以推荐用一个公共地方存放所有的URL。
  • 任意可能会更改的值 —— 每当你在用到字面量值的时候,你都要问一下自己这个值在未来是不是会变化。如果答案是“是”,那么这个值就应该被提取出来作为一个常量。

以上就是教你如何写出可维护的JS代码的详细内容,更多关于写出可维护的JS代码的资料请关注编程网其它相关文章!

--结束END--

本文标题: 教你如何写出可维护的JS代码

本文链接: https://www.lsjlt.com/news/125363.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 教你如何写出可维护的JS代码
    目录什么是可维护代码代码约定1.可读性2.变量和函数的命名3.变量类型透明松散耦合1.解耦html/JavaScript2.解耦css/JavaScript3.解耦应用逻辑/事件处理...
    99+
    2024-04-02
  • 怎么写出可维护的JS代码
    这篇文章主要介绍了怎么写出可维护的JS代码,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JavaScript是什么JavaScript是一种直译式的脚本语言,其解释器被称为J...
    99+
    2023-06-14
  • 如何写出可维护的css代码
    这篇文章主要介绍了如何写出可维护的css代码,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、在样式表开头添加一个注释块,用以描述这个样式表的创建日期、创建者、标记等备注信息...
    99+
    2023-06-08
  • 如何编写可维护的PL/SQL代码
    编写可维护的PL/SQL代码需要遵循一些最佳实践,以下是一些建议: 使用清晰的命名规范:给变量、函数和过程取一个有意义的名字,让...
    99+
    2024-05-08
    PL/SQL
  • 怎么编写可维护的JavaScript代码
    这篇文章主要为大家展示了“怎么编写可维护的JavaScript代码”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么编写可维护的JavaScript代码”这篇文...
    99+
    2024-04-02
  • 如何JS代码变得更加优雅且可维护
    本篇内容介绍了“如何JS代码变得更加优雅且可维护”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!语义化首先便...
    99+
    2024-04-02
  • PHP PDO 最佳实践:写出健壮且可维护的代码
    1. 采用 prepared statement Prepared statement 是一种预编译的 SQL 语句,可以防止 SQL 注入。在使用 prepared statement 时,将查询参数作为参数传递,而不是直接嵌入 SQ...
    99+
    2024-02-17
    PHP PDO 最佳实践 数据访问层 SQL 注入
  • 如何写出优雅的JS 代码
    目录变量使用有意义和可发音的变量名对同一类型的变量使用相同的词汇使用可搜索的名字使用解释性变量避免费脑的猜测无需添加不必要的上下文使用默认参数代替逻辑或(与)运算函数函数参数(理想情...
    99+
    2024-04-02
  • 如何写出高质量JS代码
    这篇文章主要介绍如何写出高质量JS代码,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、如何书写可维护性的代码当出现bug的时候如果你能立马修复它是最好的,此时解决问题的四路在你脑中...
    99+
    2024-04-02
  • 如何写出可读性高的代码
    本篇内容介绍了“如何写出可读性高的代码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!清楚你的优先级代码的写...
    99+
    2024-04-02
  • 怎样写出一套可维护的CSS库
    这篇文章将为大家详细讲解有关怎样写出一套可维护的CSS库,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。怎样写出一套可维护的CSS库?不妨谈谈CSS的设计模式...
    99+
    2024-04-02
  • JavaScript 代码优化进阶指南:如何让你的代码更具可扩展性和可维护性
    使用严格模式: 严格模式 (strict mode) 是 JavaScript 的一种语法模式,可以帮助您编写更安全和更健壮的代码。它可以通过使用 use strict 来启用,并且会强制执行一些限制,如禁止使用未声明的变量和防止...
    99+
    2024-02-27
    JavaScript 代码优化、性能优化、可扩展性、可维护性
  • ASP 类最佳实践:编写可维护和可扩展的代码
    命名约定 使用明确且有意义的名称,避免缩写和模糊名称。 为类、方法和变量使用 Pascal 大小写。 对于局部变量,使用骆驼大小写。 使用适当的命名空间组织类。 单一职责原则 将类设计为具有单一明确的职责。 避免创建复杂或多功能的类...
    99+
    2024-04-02
  • 如何使用PHP7的特性编写更加简洁和可维护的代码?
    如何使用PHP7的特性编写更加简洁和可维护的代码随着PHP7的发布,它引入了一些新的功能和特性,这些特性为开发人员提供了更多的选择,以编写更加简洁和可维护的代码。在本文中,我们将探讨一些使用PHP7特性的最佳实践,并提供一些具体的代码示例。...
    99+
    2023-10-22
    PHP特性 简洁代码 可维护代码
  • PHP 函数的可重用性:如何编写易于维护和扩展的代码
    php 函数的可重用性:通过封装通用功能,可重用函数减少了重复并提高了代码清晰度。为了编写可重用的函数,请:定义函数的参数和返回值。使用命名空间来组织函数。使用类和特性来分组函数。 P...
    99+
    2024-04-12
    php 函数 可重用性
  • PHP 函数如何提升代码的可读性和可维护性?
    php 函数通过将代码块分组,增强了代码的可读性和可维护性。其优点包括:可复用性:减少重复代码,节省时间。模块化:将代码组织成逻辑块,方便维护和更新。可读性:函数名称描述功能,使代码易于...
    99+
    2024-04-18
    php 代码可读性
  • 一篇文章教你写出干净的JavaScript代码
    目录1. 变量使用有意义的名称避免添加不必要的上下文避免硬编码值2. 函数使用有意义的名称使用默认参数限制参数的数量避免在一个函数中做太多事情避免使用布尔标志作为参数避免写重复的代码...
    99+
    2024-04-02
  • Golang函数的劣势如何影响代码的可维护性?
    函数劣势对 go 代码的可维护性影响:没有显式接收器:导致代码难以理解和修改,特别是处理多个相关类型的函数。范型缺乏:造成代码重复,因为必须为每种参数类型编写单独的函数。没有函数重载:扩...
    99+
    2024-04-11
    golang 代码可维护性 重构代码
  • 如何高效的编写可维护的Golang函数?
    编写高效且可维护的 go 函数的关键准则包括:保持函数短小精悍、专注于单一职责、使用清晰的方法签名、检查错误并返回清晰信息、使用文档注释进行注释。遵循这些指南可以创建更清晰、更易于测试和...
    99+
    2024-04-12
    可维护性 go函数 golang
  • 怎么写出干净的JS代码
    本篇内容介绍了“怎么写出干净的JS代码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 将数字定义为常量...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作