Node.js における path.join() の利点の分析

Node.js における path.join() の利点の分析

文字列連結ではなく path.join() メソッドを使用する必要があるのはなぜか疑問に思うかもしれません。

'/path' + '/' + 'to' + '/' + 'test.txt' // '/path/to/test.txt'
 
['/path', 'to', 'test.txt'].join('/') // '/path/to/test.txt'

1. Windows のサポート。 Windows では、パス区切り文字としてスラッシュ (/) ではなくバックスラッシュ (\) を使用します。

path.join() がこれを処理します。 path.join('data', 'test.txt') は、Windows だけでなく Linux と OSX でも 'data/test.txt' を返すためです。

2. エッジケースを処理するために使用されます。ファイル システム パスを操作する場合、多くのエッジ ケースが発生します。

たとえば、2 つのパスを手動で連結しようとすると、誤ってパス区切り文字が重複してしまう可能性があります。 path.join() メソッドは先頭と末尾のスラッシュを処理します。

path.join('data', 'test.txt') // 'data/test.txt'
path.join('data', '/test.txt') // 'data/test.txt'
path.join('data/', 'test.txt') // 'data/test.txt'
path.join('data/', '/test.txt') // 'data/test.txt'

知識ポイントの拡張:

1. path.join() メソッド

path.join() メソッドは複数のパラメータ文字列をパス文字列に結合します。

console.log(path.join(__dirname,'a','b'));現在のファイルのパスが E:/node/1 の場合、連結されたパスは E:/node/1/a/b になります。

console.log(path.join(__dirname,'/a','/b','…'));パスの先頭の / は連結に影響しません。… は前のレベルのファイルを表し、連結結果はE:/node/1/aになります。

console.log(path.join(__dirname,'a',{},'b'));また、path.join() はパス文字列の検証にも役立ちます。文字列が不正な場合は、エラーがスローされます: パスは文字列である必要があります。

2. path.resolve() メソッド

path.resolve()メソッドは、プログラムをルートディレクトリとして開始点として使用し、パラメータに基づいて絶対パスを解決します。

アプリケーションをルートディレクトリとして使用する

通常の文字列はサブディレクトリを表す

/ は絶対パスのルートディレクトリを表します

console.log(path.resolve());アプリケーションの起動ファイルのディレクトリを取得します (現在の実行ファイルの絶対パスを取得します) E:\zf\webpack\1\src

console.log(path.resolve('a','/c')); E:/c 、/ スラッシュはルートディレクトリを表すため、結果は E:/c になります。

そのため、スプライシング時に/スラッシュを使用するときは注意が必要です。

console.log(path.resolve(__dirname,'img/so')); E:\zf\webpack\1\src\img\soこれは、パスが実際に存在するかどうかに関係なく、ファイル パスを連結します。

console.log(path.resolve('wwwroot', 'static_files/png/', '…/gif/image.gif')) E:\zf\webpack\1\src\wwwroot\static_files\gif\image.gif

最初の文字列が / で始まっていないため、これは現在のアプリケーション起動ファイルの絶対パスと後続のすべての文字列の連結です。

...親ディレクトリも表します。

Node.js における path.join() の利点に関するこの記事はこれで終わりです。Node.js における path.join() の利点についてさらに詳しく知りたい場合は、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

<<:  ova ファイルを VMware にインポートする際の落とし穴の概要

>>:  Alibaba Cloud Server Ubuntu 上の Workbench が MySQL に接続できない問題の解決策 (テスト済み)

推薦する

HTML iframe で親ページと子ページ間の双方向メッセージングを実装する例

ある日、リーダーはメイン ページに iframe を埋め込み、親ページと子ページ間で双方向にメッセー...

Linux で特殊文字のファイル名やディレクトリを削除する方法

inode番号でファイルを削除するまずls -iを使用して、削除するファイルのinode番号を見つけ...

MySQL 面接でよく聞かれる質問への回答

序文:さまざまな技術職の面接では、MySQL 関連の質問がよくされるようです。開発職の面接でも運用職...

WebpackはCSSファイルを読み込み、その設定方法

webpackはCSSファイルとその設定をロードします複数の CSS ファイルを作成した後、HTML...

Taobao ストアでズームインする効果は、スライドショーを使用する原理に似ています。

今日は、スライドを使用する原理に似た、Taobao のフロントエンドのマウス ズーム効果に慣れました...

Reactの簡単な紹介

目次1. CDNの紹介1.1 react (最初にインポート) 1.2 react-dom(後ほど紹...

Vue における属性とプロパティの具体的な使用法と違い

目次Vue.jsにおける属性とプロパティ値および関連する処理として属性とプロパティの概念属性とプロパ...

HTML の title 属性を正しく使用するためのヒント

コンテンツを携帯電話、タブレット、支援技術のユーザーから非表示にし、キーボードのユーザーにのみ表示す...

テーブルタグ(テーブル)詳細

<br />テーブルは、昔から誰もが使ってきたタグで、今も使われています。しかし、現在の...

Linuxのtopコマンド出力の詳細な説明

序文皆さんは Linux で top コマンドを使ったことがあると思います。私は Linux に触れ...

MySQLのバックアップとリカバリの簡単な分析

目次1. はじめに2. バックアップとリカバリの簡単な定義3. 復旧計画で考慮すべきいくつかの要素4...

JS配列メソッドの詳細な説明

目次1. 元の配列が変更されます1. プッシュ(): 2.ポップ(): 3. シフト(): 4.un...

JavaScript は div マウス ドラッグ効果を実装します

この記事では、divマウスドラッグ効果を実現するためのJavaScriptの具体的なコードを参考まで...

大規模なウェブサイトアーキテクチャを設計・構築する際に考慮すべき10の課題

ここでは、PHP、JSP、または .NET 環境については説明しません。アーキテクチャの観点から問題...