当前位置: 首页 > news >正文

【Node.js】深度解析常用核心模块-path模块

✅ 作者简介:一名将要迈入大三的大学生,致力于提高前端开发能力
✨ 个人主页:前端小白在前进的主页
🔥 系列专栏 : node.js学习专栏
⭐️ 个人社区 : 个人交流社区
🍀 学习格言: ☀️ 打不倒你的会使你更强!☀️

🔥前言

在node.js中常用的三大模块中还有一个是path模块,主要是为了便利用户处理路径问题,如果我们在引入文件的时候经常会受到.././的干扰,那么这个path模块将会很好的帮助你!

📃目录

  • 相对路径和绝对路径
    • 相对路径和绝对路径的概念
    • 路径特殊符号
  • path 路径模块
    • 什么是path路径模块
    • 获取路径名path.dirname()
    • 路径拼接 path.join()
    • 获取路径中文件名 path.basename()
    • 获取路径中文件扩展名 path.extname()
    • 解析为绝对路径 path.resolve()
    • 返回相对路径 path.relative(from, to)
  • 小结

相对路径和绝对路径

相对路径和绝对路径的概念

在这里首先先复习一下相对路径和绝对路径:

  • 绝对路径 : 文件真实的存放位置 (以Web 站点根目录为参考基础的目录路径。之所以称为绝对,意指当所有网页引用同一个文件时,所使用的路径都是一样的。其实绝对路径与相对路径的不同处,只在于描述目录路径时,所采用的参考点不同。由于对网站上所有文件而言,根目录这个参考点对所有文件都是一样的,因此,运用以根目录为参考点的路径描述方式才会被称之为绝对路径)
  • 相对路径 : 相对于当前位置的路径 (以引用文件之网页所在位置为参考基础,而建立出的目录路径。因此,当保存于不同目录的网页引用同一个文件时,所使用的路径将不相同,故称之为相对)

路径特殊符号

"./" ------ 代表目前所在的目录,相对路径
"../" ------ 代表上一层目录,相对路径
"../../" ------ 代表的是上一层目录的上一层目录,相对路径
"/" ------ 代表根目录,绝对路径
"C:/users/" ------ 代表根目录,绝对路径

示例:
一般情况下我们不会去使用绝对路径引入文件,一般使用相对路径,因为相对路径会更加的灵活,以及在书写的项目上线的时候使用绝对路径将很麻烦,相对路径yyds!

现在需要实现一个小功能,将该图片以不同形式引入到html文件中:
在这里插入图片描述

  • 绝对路径
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
    img {
        width: 1200px;
        height: 700px;
    }
</style>
<body>
    <img src="/image/23on23-01_2.jpg" alt="">
</body>
</html>

在这里使用了路径符号//这个符号代表了根目录(D:/node复盘/03)。

  • 相对路径
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
    img {
        width: 1200px;
        height: 700px;
    }
</style>
<body>
    <img src="./image/23on23-01_2.jpg" alt="">
</body>
</html>

在这里使用了路径符号./,./代表了目前所在的目录(D:/node复盘/03)。

成功引入:
在这里插入图片描述

path 路径模块

什么是path路径模块

path 模块是 Node.js 官方提供的、用来处理路径的模块。它提供了一系列的方法和属性,用来满足用户对路径的处理需求。

获取路径名path.dirname()

返回 path 的目录名。 尾部的目录分隔符将被忽略。语法格式:
path.dirname(path)

代码示例:

const path = require('path')
console.log(path.dirname(`D:/node/02/hello.js`));  // D:/node/02

这个方法打印出了目录名D:/node/02

路径拼接 path.join()

使用 path.join() 方法,可以把多个路径片段拼接为完整的路径字符串,语法格式如下:
path.join([...paths])

参数解读:

  1. …paths < string > 路径片段的序列
  2. 返回值: < string >

代码示例:

const path = require('path')
//   注意: ../会抵消前面的路径
const pathStr = path.join('/a','/b/c','../','./c','/d')
console.log(pathStr);  //   \a\b\c\d

首先要引入path模块,node中引入模块使用内置的方法require(),如上例中写多个字符串,最后打印出来了\a\b\c\d,就是join的拼接功能,但是在这里要注意一点:../会抵消前面的路径,比如在案例中../抵消了/c

获取路径中文件名 path.basename()

使用 path.basename() 方法,可以获取路径中的最后一部分,常通过该方法获取路径中的文件名,语法格式如下:
path.basename(path[, ext])

参数解读:

  1. path: 文件路径
  2. ext: 文件扩展名

代码示例:

const path = require('path')

// 定义文件的存放路径
const fpath = '/a/b/c/index.html'

const fullName = path.basename(fpath)
console.log(fullName) // index.html

const nameWithoutExt = path.basename(fpath, '.html')
console.log(nameWithoutExt) // index

当没有传入第二个参数的时候,返回的将是路径的最后部分,所以返回了index.html,当第二个参数传入时,将会在第一种情况的基础下裁剪掉第二个参数值,所以返回了index

获取路径中文件扩展名 path.extname()

使用 path.extname() 方法,返回路径中文件的后缀名,即路径中最后一个'.'之后的部分。如果一个路径中并不包含'.'或该路径只包含一个'.' 且这个'.'为路径的第一个字符,则此命令返回空字符串。语法格式如下:
path.extname(path)
参数path:传入的路径

代码示例:

const path = require('path')

const fpath = '/a/b/c/index.html'

const fext = path.extname(fpath)
console.log(fext) // .html

这个方法与上边的方法不同的在于提取了后缀名!

解析为绝对路径 path.resolve()

path.resolve() 该方法将一些的 路径/路径段 解析为绝对路径,语法格式如下:
path.resolve( [from…],to )
注 :将参数to位置的字符解析到一个绝对路径里,[from … ]为选填项,路径源;

参数解读:

  1. from : 源路径
  2. to : 将被解析到绝对路径的字符串

代码示例:

const path = require('path)
path.resolve('/foo/bar', './baz')   // returns '/foo/bar/baz'
path.resolve('/foo/bar', 'baz')   // returns '/foo/bar/baz'
path.resolve('/foo/bar', '/baz')   // returns '/baz'
path.resolve('/foo/bar', '../baz')   // returns '/foo/baz'
path.resolve('home','/foo/bar', '../baz')   // returns '/foo/baz'
path.resolve('home','./foo/bar', '../baz')   // returns '/home/foo/baz'
path.resolve('home','foo/bar', '../baz')   // returns '/home/foo/baz'
path.resolve('home', 'foo', 'build','aaaa','aadada','../../..', 'asset') //return '/home/foo/asset'

从后向前,若字符以 / 开头,不会拼接到前面的路径;若以../开头,拼接前面的路径,且不含最后一节路径;若连续出现多个../../..或者../..则忽略前方n(这个n代表的是出现了几个..)个..路径名进行拼接;若以./开头 或者没有符号 则拼接前面路径;

返回相对路径 path.relative(from, to)

path.relative() 方法根据当前工作目录返回 from 到 to 的相对路径。 如果 from 和 to 各自解析到相同的路径(分别调用 path.resolve() 之后),则返回零长度的字符串。
如果将零长度的字符串传入 from 或 to,则使用当前工作目录代替该零长度的字符串。

代码示例:

const path = require('path')
path.relative('/data/orandea/test/aaa', '/data/orandea/impl/bbb');
// 返回: '../../impl/bbb'

该代码表达的是对于from参数来说,to参数的位置是在哪里,通过解析后得出../../impl/bbb

小结

node的内置模块中path模块的实战操作在于当你需要获取文件的名称时候可以达到灵活使用的目的,一般情况下我们只需要文章的前四种方法,最后两种方法是对path模块的一个小拔高,继续加油吧!

相关文章:

  • C语言指针操作(六)*返回指针值的函数
  • 10. Vue 常用的修饰符的作用详解?
  • 第五篇 python 基本语法(一)
  • 猿创征文| JAVA Web的环境部署
  • Python基础(一) | Python的基本语法
  • 110道Java初级面试题及答案(最新Java初级面试题大汇总)
  • 简易版实现vue1.0
  • 6大面试技能树:JAVA基础+JVM+算法+数据库+计算机网络+操作系统,时刻为面试做准备!!
  • sobel算子边缘提取及程序优化(C语言)
  • python数据结构与算法
  • cookie,storage,sesstion区别
  • 学生家乡网页设计作品静态HTML网页—— HTML+CSS+JavaScript制作辽宁沈阳家乡主题网页源码(11页)
  • MKD调试下载的时候提示:Contents mismatch at: xxxxxxxxH (Flash=xxH Required=xxH)
  • 【Python基础入门技能树笔记】数据类型-基本数据类型
  • springboot下使用druid-spring-boot-starter
  • Android 控件背景颜色处理
  • Git学习与使用心得(1)—— 初始化
  • gulp 教程
  • Java超时控制的实现
  • MySQL用户中的%到底包不包括localhost?
  • oldjun 检测网站的经验
  • SpringCloud集成分布式事务LCN (一)
  • Spring核心 Bean的高级装配
  • 第13期 DApp 榜单 :来,吃我这波安利
  • 分类模型——Logistics Regression
  • 给第三方使用接口的 URL 签名实现
  • 力扣(LeetCode)965
  • 排序算法学习笔记
  • 问:在指定的JSON数据中(最外层是数组)根据指定条件拿到匹配到的结果
  • 物联网链路协议
  • 限制Java线程池运行线程以及等待线程数量的策略
  • 学习使用ExpressJS 4.0中的新Router
  • 一些css基础学习笔记
  • 交换综合实验一
  • ​sqlite3 --- SQLite 数据库 DB-API 2.0 接口模块​
  • (14)学习笔记:动手深度学习(Pytorch神经网络基础)
  • (C#)Windows Shell 外壳编程系列9 - QueryInfo 扩展提示
  • (C语言)逆序输出字符串
  • (二)Pytorch快速搭建神经网络模型实现气温预测回归(代码+详细注解)
  • (附源码)springboot青少年公共卫生教育平台 毕业设计 643214
  • (附源码)springboot人体健康检测微信小程序 毕业设计 012142
  • (官网安装) 基于CentOS 7安装MangoDB和MangoDB Shell
  • (五)大数据实战——使用模板虚拟机实现hadoop集群虚拟机克隆及网络相关配置
  • (五)网络优化与超参数选择--九五小庞
  • (一)python发送HTTP 请求的两种方式(get和post )
  • (转)C#开发微信门户及应用(1)--开始使用微信接口
  • (转)菜鸟学数据库(三)——存储过程
  • (轉貼) VS2005 快捷键 (初級) (.NET) (Visual Studio)
  • .net core 6 集成和使用 mongodb
  • .NET Core WebAPI中使用Log4net 日志级别分类并记录到数据库
  • .NET Core 实现 Redis 批量查询指定格式的Key
  • .NET Core 网络数据采集 -- 使用AngleSharp做html解析
  • .NET Framework杂记
  • .Net 转战 Android 4.4 日常笔记(4)--按钮事件和国际化
  • .NET/C# 编译期能确定的字符串会在字符串暂存池中不会被 GC 垃圾回收掉