JavaScript ES の驚くべき新機能(4)

Nov 02, 2024 pm 06:20 PM

Incredible New Features in JavaScript ES(4)

最新の ECMAScript バージョン ES15 には、JavaScript 開発者に優れた開発エクスペリエンスを提供するいくつかの新機能が導入されています。これらの機能強化は、更新された Javascript 構文やデータ処理から、セキュリティ、パフォーマンス、開発者の生産性を高めるツールの進歩に至るまで、さまざまな分野に及びます。

1. 配列のグループ化

ES15 で最もエキサイティングな (私の個人的なお気に入りでもある) 機能の 1 つは、Object.groupBy() メソッドです。
この方法により、特定の基準に基づいて配列内の要素をグループ化する方法が簡素化されます。これにより、データ操作がより効率的になり、エラーが発生しにくくなります。

例:

const cities = [
  { name: 'Melbourne', country: 'Australia' },  
  { name: 'Auckland', country: 'New Zealand' },
  { name: 'Sydney', country: 'Australia' },
  { name: 'Brisbane', country: 'Australia' },
  { name: 'Wellington', country: 'New Zealand' }
];

const groupedByCountry = Object.groupBy(cities, fruit => fruit.country);
console.log(groupedByCountry);

// Output:
// {
//   "Australia": [
//       { "name": "Melbourne", "country": "Australia" },
//       { "name": "Sydney", "country": "Australia" },
//       { "name": "Brisbane", "country": "Australia" }
//   ],
//   "New Zealand": [
//       { "name": "Auckland", "country": "New Zealand" },
//       { "name": "Wellington", "country": "New Zealand" }
//   ]
// }
ログイン後にコピー
ログイン後にコピー

この機能を使用すると、配列のグループ化に従来使用していたカスタム関数やサードパーティ ライブラリの必要性を減らすことができます。

また、この機能を使用すると、意図を直接表現することでコードをより理解しやすく、保守しやすくすることができます

2. パイプライン演算子 (|>)

場合によっては、連鎖プロセスとして複数の関数を使用する必要があります。このようなシナリオでは、パイプライン演算子 (|>) を使用してチェーン プロセスを簡素化できます。

例:

const double = (x) => x * 2;
const increment = (x) => x + 1;
const square = (x) => x * x;

const result = 5 |> double |> increment |> square;

// Output: 121
ログイン後にコピー
ログイン後にコピー

上記の従来の方法は次のとおりです

const double = (x) => x * 2;
const increment = (x) => x + 1;
const square = (x) => x * x;

const result = square(increment(double(5)));
console.log(result);

// Output: 121
ログイン後にコピー

パイプライン演算子を使用すると、より関数型のプログラミング スタイルを使用できます。そこから、深くネストされた関数呼び出しの複雑さを取り除くことで、コードをより読みやすくすることができます。

3. メソッド連鎖演算子 (?.())

ES15 は、新しいメソッド チェーン オペレーターを導入することにより、オプションのチェーンを拡張します。このメソッド連鎖演算子は、深くネストされたオブジェクトでのメソッド呼び出しの安全性を高めます。

例:

const data = {
  user: {
    getName: () => 'Tim'
  }
};

console.log(data.user?.getName?.());  // Output: 'Alice'
console.log(data.user?.getAge?.());  // Output: undefined
ログイン後にコピー

メソッド連鎖演算子 (?.()) を使用すると、null または未定義の可能性のあるオブジェクトのメソッドを安全に呼び出すことができます。これにより、メソッドの呼び出しによって発生する実行時エラーのリスクが軽減されます。

4. Set メソッドの機能強化

ES15 では、unionintersectiondifferencesymmetricDifference などの新しいメソッドを含め、Set オブジェクトにいくつかの機能強化が導入されています。これらのメソッドは、一般的な集合演算を簡素化します。

const setA = new Set([1, 2, 3]);
const setB = new Set([3, 4, 5]);

const unionSet = setA.union(setB);
const differenceSet = setA.difference(setB);
const intersectionSet = setA.intersection(setB);
const symmetricDifferenceSet = setA.symmetricDifference(setB);

console.log(unionSet); // Output: {1, 2, 3, 4, 5}
console.log(differenceSet); // Output: {1, 2}
console.log(intersectionSet); // Output: {3}
console.log(symmetricDifferenceSet); // Output: {1, 2, 4, 5}
ログイン後にコピー
  • 結合
    Set インスタンスの Union() メソッドは、セットを受け取り、このセットと指定されたセットのいずれかまたは両方に含まれる要素を含む新しいセットを返します。

  • 違い
    Set インスタンスのDifference() メソッドは、セットを受け取り、このセット内ではあるが、指定されたセット内には含まれていない要素を含む新しいセットを返します。

  • 交差点
    Set インスタンスの Intersection() メソッドは、セットを受け取り、このセットと指定されたセットの両方の要素を含む新しいセットを返します。

  • 対称差
    Set インスタンスの metricDifference() メソッドは、セットを受け取り、このセットまたは指定されたセットのいずれかに含まれる要素を含む新しいセットを返します。

5. 強化された JSON モジュール

以前の ECMAScript バージョンでは、開発者はバンドラーまたはローダーに依存して JSON ファイルをインポートしていました。 ES15 では、動的なインポートとスキーマ検証がサポートされるようになりました。これにより、構造化データの操作が容易になり、インポートされたデータが期待される形式に準拠していることが保証されます。

JavaScript モジュールをインポートするのと同じように、JSON データを直接インポートできるようになりました。

例:

const cities = [
  { name: 'Melbourne', country: 'Australia' },  
  { name: 'Auckland', country: 'New Zealand' },
  { name: 'Sydney', country: 'Australia' },
  { name: 'Brisbane', country: 'Australia' },
  { name: 'Wellington', country: 'New Zealand' }
];

const groupedByCountry = Object.groupBy(cities, fruit => fruit.country);
console.log(groupedByCountry);

// Output:
// {
//   "Australia": [
//       { "name": "Melbourne", "country": "Australia" },
//       { "name": "Sydney", "country": "Australia" },
//       { "name": "Brisbane", "country": "Australia" }
//   ],
//   "New Zealand": [
//       { "name": "Auckland", "country": "New Zealand" },
//       { "name": "Wellington", "country": "New Zealand" }
//   ]
// }
ログイン後にコピー
ログイン後にコピー
const double = (x) => x * 2;
const increment = (x) => x + 1;
const square = (x) => x * x;

const result = 5 |> double |> increment |> square;

// Output: 121
ログイン後にコピー
ログイン後にコピー

ただし、この変更により、JSON をインポートする古い非標準の方法に依存するコード、または特定のビルド ツールが古い動作で構成されている場合、コードが壊れる可能性があります。

以上がJavaScript ES の驚くべき新機能(4)の詳細内容です。詳細については、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)

独自のJavaScriptライブラリを作成および公開するにはどうすればよいですか? 独自のJavaScriptライブラリを作成および公開するにはどうすればよいですか? Mar 18, 2025 pm 03:12 PM

記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

ブラウザでのパフォーマンスのためにJavaScriptコードを最適化するにはどうすればよいですか? ブラウザでのパフォーマンスのためにJavaScriptコードを最適化するにはどうすればよいですか? Mar 18, 2025 pm 03:14 PM

この記事では、ブラウザでJavaScriptのパフォーマンスを最適化するための戦略について説明し、実行時間の短縮、ページの負荷速度への影響を最小限に抑えることに焦点を当てています。

フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? Apr 04, 2025 pm 02:42 PM

フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

ブラウザ開発者ツールを使用してJavaScriptコードを効果的にデバッグするにはどうすればよいですか? ブラウザ開発者ツールを使用してJavaScriptコードを効果的にデバッグするにはどうすればよいですか? Mar 18, 2025 pm 03:16 PM

この記事では、ブラウザ開発者ツールを使用した効果的なJavaScriptデバッグについて説明し、ブレークポイントの設定、コンソールの使用、パフォーマンスの分析に焦点を当てています。

誰がより多くのPythonまたはJavaScriptを支払われますか? 誰がより多くのPythonまたはJavaScriptを支払われますか? Apr 04, 2025 am 12:09 AM

スキルや業界のニーズに応じて、PythonおよびJavaScript開発者には絶対的な給与はありません。 1. Pythonは、データサイエンスと機械学習でさらに支払われる場合があります。 2。JavaScriptは、フロントエンドとフルスタックの開発に大きな需要があり、その給与もかなりです。 3。影響要因には、経験、地理的位置、会社の規模、特定のスキルが含まれます。

ソースマップを使用して、マイナイドJavaScriptコードをデバッグするにはどうすればよいですか? ソースマップを使用して、マイナイドJavaScriptコードをデバッグするにはどうすればよいですか? Mar 18, 2025 pm 03:17 PM

この記事では、ソースマップを使用して、元のコードにマッピングすることにより、Minified JavaScriptをデバッグする方法について説明します。ソースマップの有効化、ブレークポイントの設定、Chrome DevtoolsやWebpackなどのツールの使用について説明します。

JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? Apr 04, 2025 pm 05:09 PM

同じIDを持つ配列要素をJavaScriptの1つのオブジェクトにマージする方法は?データを処理するとき、私たちはしばしば同じIDを持つ必要性に遭遇します...

Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Apr 04, 2025 pm 05:12 PM

Console.log出力の違いの根本原因に関する詳細な議論。この記事では、Console.log関数の出力結果の違いをコードの一部で分析し、その背後にある理由を説明します。 �...

See all articles