文字列連結ではなく 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 に接続できない問題の解決策 (テスト済み)
ドラッグ アンド ドロップ API は、ドラッグ可能な要素を HTML に追加し、ドラッグ可能な豊富...
キーの入力を求められた場合は、[キーがありません]を選択します。デスクトップエクスペリエンスを選択す...
序文これまで遭遇したデータベースのデッドロックはすべて、バッチ更新中のロック順序の不一致が原因でした...
MySQL DATE_ADD(date,INTERVAL expr type) 関数と ADDDA...
1. 上部と下部のリストタグ: <dl>..</dl>:上dt下層dd: カ...
シングルページアプリケーションを開発する場合、特定のルートを入力し、パラメータに基づいてサーバーから...
この記事はMySQL 5.7.23 winx64のインストールチュートリアルを記録します。具体的な内...
1. MySQL 8.0.12 バージョンのインストール手順。 1. ダウンロードhttps://d...
MySQL 全文検索中国語ソリューション最近、会社のプロジェクトで、データベースで中国語を検索する機...
インターネットにはすでにこの種の記事が溢れていますが、私がこれをまだ書いている理由は単純です。それは...
目次Reactの公式サイトではライフサイクルの説明を見ることができます次に、ネストされたコンポーネン...
最近、WeChat アプレットを作成しているのですが、いくつか問題が発生しました。インターネットでい...
この記事では、例を使用して、MySQL イベントの変更 (ALTER EVENT)、イベントの無効化...
序文最近、MySQL のインデックスについて読んでいました。結合されたインデックスを見ると、左端の原...
目次序文1. インストール1.公式サイトからダウンロード2. 構成を作成する3. MySQLを初期化...