目次
1.语义化命名
2.各种类型命名
3.为常量声明
4.避免上下文依赖
5.避免冗余命名
6.使用参数默认值
7.回调函数命名
8.减少函数的参数个数
9.函数拆分
10.注重写注释
ホームページ ウェブフロントエンド 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 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C++ 関数宣言のデフォルト パラメーター: それらの宣言と使用法の包括的な分析 C++ 関数宣言のデフォルト パラメーター: それらの宣言と使用法の包括的な分析 May 02, 2024 pm 03:09 PM

C++ のデフォルト パラメーターは、関数パラメーターのデフォルト値を指定する機能を提供するため、コードの読みやすさ、単純さ、柔軟性が向上します。デフォルトのパラメータを宣言する: 関数宣言のパラメータの後に「=」記号を追加し、その後にデフォルト値を追加します。使用法: 関数が呼び出されるとき、オプションのパラメーターが指定されていない場合は、デフォルト値が使用されます。実際のケース: 2 つの数値の合計を計算する関数。1 つのパラメーターは必須で、もう 1 つはオプションであり、デフォルト値は 0 です。利点: 可読性の向上、柔軟性の向上、定型コードの削減。注: これは宣言でのみ指定でき、最後に指定する必要があり、型に互換性がある必要があります。

C言語でのrestrictの使い方 C言語でのrestrictの使い方 May 08, 2024 pm 01:30 PM

strict キーワードは、変数にはポインターによってのみアクセスできることをコンパイラーに通知するために使用され、未定義の動作を防止し、コードを最適化し、読みやすさを向上させます。複数のポインターが同じ変数を指している場合の未定義の動作を防止します。コードを最適化するために、コンパイラは、restrict キーワードを使用して変数アクセスを最適化します。変数にはポインターによってのみアクセスできることを示すことで、コードの可読性が向上します。

Vue での ref の用途は何ですか? Vue での ref の用途は何ですか? May 02, 2024 pm 08:39 PM

Vue.js の ref は、次の目的でテンプレートと JavaScript コード間の参照を確立するために使用されます。 DOM 要素またはコンポーネント インスタンスにアクセスする DOM イベントをリッスンする DOM を動的に作成し、サードパーティ ライブラリと統合する

PHP のオブジェクト リレーショナル マッピングとデータベース抽象化レイヤーによってコードの可読性が向上する仕組み PHP のオブジェクト リレーショナル マッピングとデータベース抽象化レイヤーによってコードの可読性が向上する仕組み May 06, 2024 pm 06:06 PM

回答: ORM (オブジェクト リレーショナル マッピング) と DAL (データベース抽象化レイヤー) は、基礎となるデータベース実装の詳細を抽象化することでコードの可読性を向上させます。詳細な説明: ORM はオブジェクト指向のアプローチを使用してデータベースと対話し、コードをアプリケーション ロジックに近づけます。 DAL は、データベース ベンダーに依存しない共通のインターフェイスを提供し、さまざまなデータベースとの対話を簡素化します。 ORM と DAL を使用すると、SQL ステートメントの使用が減り、コードがより簡潔になります。実際のケースでは、ORM と DAL により製品情報のクエリが簡素化され、コードの可読性が向上します。

テンプレートプログラミングはどのようなメリットをもたらしますか? テンプレートプログラミングはどのようなメリットをもたらしますか? May 08, 2024 pm 05:54 PM

テンプレート化されたプログラミングにより、次の理由によりコードの品質が向上します。 可読性が向上します。 反復的なコードがカプセル化され、理解しやすくなります。保守性の向上: データ型の変更に対応するには、テンプレートを変更するだけです。最適化の効率: コンパイラーは、特定のデータ型に対して最適化されたコードを生成します。コードの再利用を促進する: 再利用できる共通のアルゴリズムとデータ構造を作成します。

PHP 関数の新機能により開発プロセスはどのように簡素化されるのでしょうか? PHP 関数の新機能により開発プロセスはどのように簡素化されるのでしょうか? May 04, 2024 pm 09:45 PM

PHP 関数の新機能により、次のような開発プロセスが大幅に簡素化されます。 アロー関数: コードの冗長性を減らすための簡潔な匿名関数構文を提供します。プロパティの型宣言: クラス プロパティの型を指定し、コードの可読性と信頼性を向上させ、実行時に型チェックを自動的に実行します。 null 演算子: null 値を簡潔にチェックして処理し、オプションのパラメーターの処理に使用できます。

C++ 関数の命名規則: 関数名を仕様に準拠させるにはどうすればよいですか? C++ 関数の命名規則: 関数名を仕様に準拠させるにはどうすればよいですか? May 05, 2024 am 08:42 AM

C++ 関数の命名規則では、関数名が関数の動作を正確に説明すること、簡潔かつ明確であること、動詞形式を使用すること、アンダースコアを避けること、キーワードを使用しないこと、パラメーターと戻り値の情報を含めることができることを要求します。これらの原則に従うと、コードの可読性と保守性が向上します。

ドキュメントのコメントと C++ 関数の命名規則との間の補完的な関係 ドキュメントのコメントと C++ 関数の命名規則との間の補完的な関係 May 03, 2024 am 09:00 AM

C++ の関数命名規則とドキュメント コメントは相互に補完し、コードの読みやすさを向上させます。命名規則によって明確で一貫した関数名が提供され、ドキュメントのコメントによって目的、パラメーター、戻り値、前提条件などの詳細が補足され、コードの理解、保守、拡張が容易になります。

See all articles