目錄
1.语义化命名
2.各种类型命名
3.为常量声明
4.避免上下文依赖
5.避免冗余命名
6.使用参数默认值
7.回调函数命名
8.减少函数的参数个数
9.函数拆分
10.注重写注释
首頁 web前端 js教程 掌握10种方法,提高你的代码可读性!

掌握10种方法,提高你的代码可读性!

Nov 16, 2020 pm 05:06 PM
程式碼可讀性

javascript栏目介绍如何提高代码可读性的方法。

掌握10种方法,提高你的代码可读性!

每个人都喜欢可读性高的代码,因为高可读性的代码总是能让人眼前一亮!
就好比你向周围的人说:快看,老师!周围的人可能不屑一顾:老师有什么好看的?但如果你说:快看,苍老师!那可能很多人会被你这句话所吸引。一字之差,结果截然不同。
代码可读性的魅力也是这样,高可读性的代码,让别人抑郁理解,能够大量减少后期的维护时间。今天总结了10条常用的提高代码可读性的小方法,望大家不吝赐教。

1.语义化命名

在声明变量时,尽量让自己的变量名称具有清晰的语义化,使他人一眼便能够看出这个变量的含义,在这种情况下,可以减少注释的使用。

示例:

// bad  别人看到会疑惑:这个list是什么的集合?const list = ['Teacher.Cang', 'Teacher.Bo', 'Teacher.XiaoZe']  

// good 别人看到秒懂:原来是老师们的集合!const teacherList = ['Teacher.Cang', 'Teacher.Bo', 'Teacher.XiaoZe']复制代码
登入後複製

2.各种类型命名

对于不同类型的变量值,我们可以通过一定的方式,让别人一看看上去就知道他的值类型。
一般来说,对于boolean类型或者Array类型的值,是最好区分的。例如:boolean类型的值可以用isXXX、hasXXX、canXXX等命名;Array类型的值可以用xxxList、xxxArray等方式命名。

// badlet belongToTeacher = true;let teachers = ['Teacher.Cang', 'Teacher.Bo', 'Teacher.XiaoZe'];// goodlet isTeacher = true;let teacherList = ['Teacher.Cang', 'Teacher.Bo', 'Teacher.XiaoZe'];复制代码
登入後複製

3.为常量声明

我们在阅读代码时,如果你突然在代码中看到一个字符串常量或者数字常量,你可能要花一定的时间去理解它的含义。如果使用const或者enum等声明一下这些常量,可读性将会有效得到提升。

示例:

// bad  别人看到会很疑惑:这个36D的含义是什么if (size === '36D') {  console.log('It is my favorite');
}// good 别人看到秒懂:36D是最喜欢的大小const FAVORITE_SIZE = '36D';if (size === FAVORITE_SIZE) {  console.log('It is my favorite');
}复制代码
登入後複製

4.避免上下文依赖

在遍历时,很多人会通过value、item甚至v等命名代表遍历的变量,但是当上下文过长时,这样的命名可读性就会变得很差。我们要尽量做到使读者即使不了解事情的来龙去脉的情况下,也能迅速理解这个变量代表的含义,而不是迫使读者去记住逻辑的上下文。

const teacherList = ['Teacher.Cang', 'Teacher.Bo', 'Teacher.XiaoZe']// bad  别人看到循环的末尾处的item时需要在去上面看上下文理解item的含义teacherList.forEach(item => {  // do something
  // do something
  // do …………
  doSomethingWith(item);
})// good 别人看到最后一眼就能明白变量的意思是老师teacherList.forEach(teacher => {  // do something
  // do something
  // do …………
  doSomethingWith(teacher);
})复制代码
登入後複製

5.避免冗余命名

某些情况的变量命名,例如给对象的属性命名,直接命名该属性的含义即可,因为本身这个属性在对象中,无需再添加多余的前缀。

// badconst teacher = {  teacherName: 'Teacher.Cang',  teacherAge: 37,  teacherSex: 'female',
};console.log(person.personName)// goodconst teacher = {  name: 'Teacher.Cang',  age: 37,  sex: 'female',
};console.log(teacher.name)复制代码
登入後複製

6.使用参数默认值

相比短路,使用ES6的参数默认值能让人更轻易地理解未传参数时参数的赋默认值。

// bad  需要多看一步才能理解是赋默认值function getTeacherInfo(teacherName) {
  teacherName = teacherName || 'Teacher.Cang';  // do...}// good 一看就能看出是赋默认值function getTeacherInfo(teacherName = 'Teacher.Cang') {  // do...}复制代码
登入後複製

7.回调函数命名

很多人命名回调函数,尤其是为页面或者DOM元素等设置事件监听的回调函数时,习惯用事件的触发条件进行命名,这样做其实可读性是比较差的,别人看到只知道你出发了这个函数,但却需要花时间去理解这个函数做了什么。
我们在命名回调函数式,应当以函数所要执行的逻辑命名,让别人清晰地理解这个回调函数所要执行的逻辑。

// bad  需要花时间去看代码理解这个回调函数是做什么的<input type="button" value="提交" onClick="handleClick" />function handleClick() {  // do...}// good 一眼就能理解这个回调函数是提交表单<input type="button" value="提交" onClick="handleSubmitForm" />;function handleSubmitForm() {  // do...}复制代码
登入後複製

8.减少函数的参数个数

一个函数如果参数的数量太多,使用的时候就难以记住每个参数的含义了,并且函数多个参数有顺序限制,我们在调用时需要去记住每个次序的参数的含义。通常情况下我们一个函数的参数个数在1-2个为佳,尽量不要超过三个。
当函数的参数比较多时,我们可以将同一类的参数使用对象进行合并,然后将合并后的对象作为参数传入,这样在调用该函数时能够很清楚地理解每个参数的含义。

// bad  调用时传的参数难以理解含义,需要记住顺序function createTeacher(name, sex, age, height, weight) {  // do...}
createTeacher('Teacher.Cang', 'female', 37, 155, 45);// good 调用时虽然写法略复杂了点,但各个参数含义一目了然,无需刻意记住顺序function createTeacher({name, sex, age, height, weight}) {  // do...}
createTeacher({  name: 'Teacher.Cang',  sex: 'female',  age: 37,  height: 155,  weight: 45})复制代码
登入後複製

9.函数拆分

一个函数如果代码太长,那么可读性也是比较差的,我们应该尽量保持一个函数只处理一个功能,当逻辑复杂时将函数适当拆分。

// badfunction initData() {  let resTeacherList = axios.get('/teacher/list');
  teacherList = resTeacherList.data;  const params = {    pageSize: 20,    pageNum: 1,
  };  let resMovieList = axios.get('/movie/list', params);
  movieList = resMovieList.data;
}// goodfunction getTeacherList() {  let resTeacherList = axios.get('/teacher/list');
  teacherList = resTeacherList.data;
}function getMovieList() {  const params = {    pageSize: 20,    pageNum: 1,
  };  let resMovieList = axios.get('/movie/list', params);
  movieList = resMovieList.data;
}function initData() {
  getTeacherList();
  getMovieList();
}复制代码
登入後複製

10.注重写注释

不写注释应该是很多开发者的一个恶习,看别人不写注释的代码也是很多开发者最讨厌的事情。
所以,无论是为了自己还是别人,都请注重编写注释。

// bad  不写注释要花大量时间理解这个函数的作用function formatNumber(num) {  if (num < 1000) {    return num;
  } else {    return `${(num / 1000).toFixed(1)}k`
  }
}// good 有了注释函数的作用和用法一目了然/**
 * @param num
 * @return num | x.xk
 * @example formatNumber(1000);
 * @description
 * 小于1k不转换
 * 大于1k转换为x.xk
 */function formatNumber(num) {  if (num < 1000) {    return num;
  } else {    return `${(num / 1000).toFixed(1)}k`
  }
}复制代码
登入後複製

提高代码可读性的代码风格其实还有很多,以上笔者主要从变量命名、函数和注释三个方面,总结了10条比较常用的提高代码可读性的方法,希望对大家有所帮助。如有补充,欢迎评论。

相关免费学习推荐:JavaScript(视频)

以上是掌握10种方法,提高你的代码可读性!的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1422
52
Laravel 教程
1316
25
PHP教程
1267
29
C# 教程
1239
24
restrict在c語言的用法 restrict在c語言的用法 May 08, 2024 pm 01:30 PM

restrict 關鍵字用於通知編譯器變數只能由一個指標訪問,防止未定義行為、最佳化程式碼並提高可讀性:防止未定義行為,當多個指標指向相同變數時。最佳化程式碼,編譯器利用 restrict 關鍵字優化變數存取方式。提高程式碼可讀性,表示變數只能由一個指標存取。

模板化程式設計能帶來什麼好處? 模板化程式設計能帶來什麼好處? May 08, 2024 pm 05:54 PM

模板化程式設計可提升程式碼質量,因為它:增強可讀性:封裝重複程式碼,使其更易於理解。提升可維護性:只需更改範本即可適應資料類型變更。最佳化效率:編譯器產生特定資料類型的最佳化程式碼。促進程式碼重複使用:建立通用的演算法和資料結構,可重複使用。

c語言函數名定義 c語言函數名定義 Apr 03, 2025 pm 10:03 PM

C語言函數名定義包括:返回值類型、函數名、參數列表和函數體。函數名應清晰、簡潔、統一風格,避免與關鍵字衝突。函數名具有作用域,可在聲明後使用。函數指針允許將函數作為參數傳遞或賦值。常見錯誤包括命名衝突、參數類型不匹配和未聲明的函數。性能優化重點在函數設計和實現上,而清晰、易讀的代碼至關重要。

C語言中 sum 是關鍵字嗎? C語言中 sum 是關鍵字嗎? Apr 03, 2025 pm 02:18 PM

C 語言中不存在 sum 關鍵字,其為普通標識符,可作為變量或函數名使用。但為了避免誤解,建議避免將其用於數學相關代碼的標識符,可以使用更具描述性的名稱,如 array_sum 或 calculate_sum,以提高代碼可讀性。

H5頁面製作是前端開發嗎 H5頁面製作是前端開發嗎 Apr 05, 2025 pm 11:42 PM

是的,H5頁面製作是前端開發的重要實現方式,涉及HTML、CSS和JavaScript等核心技術。開發者通過巧妙結合這些技術,例如使用&lt;canvas&gt;標籤繪製圖形或使用JavaScript控制交互行為,構建出動態且功能強大的H5頁面。

Go語言中`var`和`type`關鍵字定義結構體的區別是什麼? Go語言中`var`和`type`關鍵字定義結構體的區別是什麼? Apr 02, 2025 pm 12:57 PM

Go語言中結構體定義的兩種方式:var與type關鍵字的差異Go語言在定義結構體時,經常會看到兩種不同的寫法:一�...

c++中std::什麼作用 c++中std::什麼作用 May 09, 2024 am 03:48 AM

std:: 是 C++ 中包含標準函式庫函數、類別和物件的命名空間,簡化了軟體開發。其具體作用包括:提供資料結構容器,如向量和集合;提供遍歷容器的迭代器;包含各種演算法用於操作資料;提供輸入/輸出流物件用於處理I/O 操作;提供其他實用工具,如異常處理和記憶體管理。

C語言中void的作用 C語言中void的作用 Apr 03, 2025 pm 04:12 PM

在 C 語言中,void 是一個關鍵字,表示無返回值。它被用於各種場景,例如:聲明無返回值的函數:void print_message();聲明無參數的函數:void print_message(void);定義無返回值的函數:void print_message() { printf(&amp;quot;Hello world\n&amp;quot;); }定義無參數的函數:void print_message(void) { printf(&amp;quot;Hell

See all articles