node path模塊

来源:http://www.cnblogs.com/createGod/archive/2017/05/30/6919869.html
-Advertisement-
Play Games

一、在nodejs中path模塊時使用頻率很高的模塊,其中不乏有很多API寫得很模糊,但仔細琢磨下來,也不是很難理解。 1.獲取文件所在路徑 2.獲取路徑中的最後一部分 3.獲取文件的拓展名 二、組合路徑 1. 路徑的拼接 path.join(); 2.path.resove(from,to);將t ...


一、在nodejs中path模塊時使用頻率很高的模塊,其中不乏有很多API寫得很模糊,但仔細琢磨下來,也不是很難理解。

1.獲取文件所在路徑

var path = require('path');
var test = '/test/test1/test2/test.js';
//獲取文件所在的目錄
console.log(path.dirname(test)); //  /test/test1/test2

2.獲取路徑中的最後一部分

var path = require('path');
var test = '/test/test1/test2/test.js';
var test1 = '/test/test1/test2/';
var test2 = '/test/test1/test2';

//獲取路徑中的最後一部分 大部分時間可以用來判斷文件名
console.log(path.basename(test)); //test.js
console.log(path.basename(test1)); // test2
console.log(path.basename(test2));//test2

3.獲取文件的拓展名

var path = require('path');
var test = '/test/test1/test2/test.js';
var file1 = '.js';
var file2 = 'js.';

//獲取文件的拓展名  其實是從最後一個 '.'開始截取的。特別需要註意的是
//如果 '.'開頭 則返回 空 , 點結尾返回 '.'
console.log(path.extname(test)); //.js
console.log(path.extname(file1)); // ''
console.log(path.extname(file2)); //'.'

二、組合路徑

1. 路徑的拼接 path.join();

var path = require('path');
var test = '/test/';
var test1 = '/test1/';
var test2 = '/test2/';

console.log(path.join(test,test1,test2));
// '\test\test1\test2';
// 為什麼會輸出這個呢 ? 其實是把 path 拼接起來在normalize一下

2.path.resove(from,to);將to 解析為絕對路徑

var path = require('path');

console.log(path.resolve('path.js')) //\express\path.js

3.path.parse();路徑的解析

var path = require('path');

//路徑的解析
console.log(path.parse('path.js'))
//{ root: '', dir: '', base: 'path.js', ext: '.js', name: 'path' }

三、規範路徑 path.normalize();

  • 如果路徑為空,返回.,相當於當前的工作路徑。
  • 將對路徑中重覆的路徑分隔符(比如linux下的/)合併為一個。
  • 對路徑中的...進行處理。(類似於shell里的cd ..
  • 如果路徑最後有/,那麼保留該/
    var path = require('path');
    var filepath = '/tmp/demo/js/test.js';
    
    var index = 0;
    
    var compare = function(desc, callback){
        console.log('[用例%d]:%s', ++index, desc);
        callback();
        console.log('\n');
    };
    
    compare('路徑為空', function(){
        // 輸出 .
        console.log( path.normalize('') );
    });
    
    compare('路徑結尾是否帶/', function(){
        // 輸出 /tmp/demo/js/upload
        console.log( path.normalize('/tmp/demo/js/upload') );
    
        // /tmp/demo/js/upload/
        console.log( path.normalize('/tmp/demo/js/upload/') );
    });
    
    compare('重覆的/', function(){
        // 輸出 /tmp/demo/js
        console.log( path.normalize('/tmp/demo//js') );
    });
    
    compare('路徑帶..', function(){
        // 輸出 /tmp/demo/js
        console.log( path.normalize('/tmp/demo/js/upload/..') );
    });
    
    compare('相對路徑', function(){
        // 輸出 demo/js/upload/
        console.log( path.normalize('./demo/js/upload/') );
    
        // 輸出 demo/js/upload/
        console.log( path.normalize('demo/js/upload/') );
    });
    
    compare('不常用邊界', function(){
        // 輸出 ..
        console.log( path.normalize('./..') );
    
        // 輸出 ..
        console.log( path.normalize('..') );
    
        // 輸出 ../
        console.log( path.normalize('../') );
    
        // 輸出 /
        console.log( path.normalize('/../') );
    
        // 輸出 /
        console.log( path.normalize('/..') );
    });

四、其中不乏有些沒有說清楚,按照API寫一遍,加上自己的理解,大概就清楚了。

祝大家端午節快樂。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 0 目錄 認證授權系列:http://www.cnblogs.com/linianhui/category/929878.html 1 什麼是OIDC? 看一下官方的介紹(http://openid.net/connect/): OpenID Connect 1.0 is a simple iden ...
  • 1.angular 調用客戶端方法放在 try catch中 try { js_invoke.showShareDialog(angular.toJson(obj)); // 在這裡放客戶端的方法即可 } catch(e) { console.log('Recommend share',obj); ...
  • jq筆記-dom篇-慕課網學習筆記 1.jQuery節點創建與屬性的處理 創建元素節點: 1.$("<div></div>") 創建為本節點: 1.$("<div>我是文本節點</div>") 創建為屬性節點: 1.$("<div id='test' class='aaron'>我是文本節點</di ...
  • 學完了Javascript類和對象的創建之後,現在總結一下Javascript繼承機制的實現。Javascript並不像Java那樣對繼承機制有嚴格明確的定義,它的實現方式正如它的變數的使用方式那樣也是十分寬鬆的,你可以設計自己的方法“模仿”繼承機制的實現。有以下幾種方法: 1、對象冒充 1 <sc ...
  • 這篇依然是跟 相關的方法,側重點是跟集合元素查找相關的方法。 讀Zepto源碼系列文章已經放到了github上,歡迎star: "reading zepto" 源碼版本 本文閱讀的源碼為 "zepto1.2.0" 內部方法 之前有一章《 "讀Zepto源碼之內部方法" 》是專門解讀 中沒有提供給外部 ...
  • 頁面編碼(告訴瀏覽器是什麼編碼) 刷新和跳轉 關鍵詞 X-UA-Compatible Title網頁頭部信息 常用標簽 表格 實例: ...
  • 學習和工作中經常會通過搜索引擎的引導進入到博客園中,技術大牛們的知識概括往往一針見血解決了困擾我很久的大大小小的問題。可是一直都是看別人寫的博客,自己一直沒動過手,直到看到一個博客說到,從簡到繁地記記讀書筆記或知識總結是促進技術進步的一個很好的方法,覺得非常在理,學習後的整理更能記得牢固,於是最近下 ...
  • 本書從現代前端開發的標準、趨勢和常用工具入手,由此引出了優秀的構建工具webpack 和JavaScript庫React,之後用一系列的實例來闡述兩者的特色、概念和基本使用方法。隨著應用複雜度的增加,進而介紹了Flux 和Redux 兩種架構思想,並且使用Redux 對現有程式進行改造,最後介紹了在 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...