node.js 学习入门(03 - path路径处理问题)

什么是 path 模块

Node.js path 模块是一个内置模块,可帮助您以独立于操作系统的方式使用文件系统路径。如果要构建支持 OSX、Linux 和 Windows 的 CLI 工具,则 Path 模块是必不可少的。

path.join 方法的使用

用于连接路径。该方法的主要用途在于,会正确使用当前系统的路径分隔符,Unix系统是"/“,Windows系统是”\"。

const path = require('path')
const fs = require('fs')

// 注意:../ 会抵消前面的一层路径
// console.log(path.join('/a', '/b/c', '../', './d', '/e')) // \a\b\d\e

// fs.readFile(__dirname + './files/1.txt', function (err, data) {
//     if (err) {
//         return console.log("读取文件失败")
//     }
//     console.log("读取文件成功")
// })

// 今后凡是涉及到路径拼接的操作,都需要使用 path.join() 方法进行处理。不要直接使用 + 进行字符串的拼接
// 使用 path.join() 方法可以直接把 . 屏蔽掉,用 + 号拼接不行会直接请求失败
fs.readFile(path.join(__dirname , './files/1.txt'), function (err, data) {
    if (err) {
        return console.log("读取文件失败")
    }
    console.log("读取文件成功")
})

path.basename 方法的使用

返回路径中的最后一部分。同 Unix 命令 bashname 类似。

const path = require('path')

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

// 获取路径的文件名
// console.log(path.basename(fpath))

// 获取路径的文件名,并去除扩展名
console.log(path.basename(fpath,'.html'))

path.extname 方法的使用

返回路径中文件的后缀名,即路径中最后一个 . 之后的部分。如果一个路径中并不包含 . 或该路径只包含一个 . 且这个 . 为路径的第一个字符,则此命令返回空字符串。

const path = require('path')

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

// 获取路径中的文件扩展名
console.log(path.extname(fpath))

path 基本案例

把一个 html 文件,更改为 htmlcssjs 三份文件
自己找一个 html 文件放在 clock 文件夹下,在 2.1 步骤处引入

// 1.1 导入 fs 模块
const fs = require('fs')
// 1.2 导入 path 模块
const path = require('path')

// 1.3 定义正则表达式,分别匹配 <style></style> 和 <script></script> 标签
// 小写 s 代表空白字符,大写 S 代表非空白字符,* 代表任意多次
const refStyle = /<style>[\s\S]*<\/style>/
const refScript = /<script>[\s\S]*<\/script>/

// 2.1 调用 fs.readFile() 方法读取文件
fs.readFile(path.join(__dirname, './files/index.html'), function (err, data) {
    // 2.2 读取 HTML 文件失败
    if (err) {
        return console.log("读取HTML文件失败!" + err.message)
    }
    // 2.3 读取文件成功后,调用对应的三个方法,分别拆解出 css,js,html 文件
    resolveCSS(data)
    resolveJS(data)
    resolveHTML(data)
})

// 3.1 定义处理 css 样式的方法
function resolveCSS(val) {
    // 3.2 使用正则提取需要的内容
    const r1 = refStyle.exec(val)
    // 3.3 将提取出来的样式字符串,进行字符串的 replace 替换操作
    const newCSS = r1[0].replace('<style>', '').replace('</style>', '')
    // 3.4 调用 fs.writeFile() 方法,将提取的样式,写入到 clock 目录中 index.css的文件里面
    fs.writeFile(path.join(__dirname, './clock/index.css'), newCSS, function (err) {
        if (err) return console.log("写入 CSS 样式失败!")
        console.log("写入样式文件成功")
    })
}

// 4.1 定义处理 js 样式的方法
function resolveJS(val) {
    // 4.2 通过正则,提取对应的 <script></script> 标签内容
    const r2 = refScript.exec(val)
    // 4.3 将提取出来的内容,做进一步处理
    const newJS = r2[0].replace('<script>', '').replace('</script>', '')
    // 4.4 调用 fs.writeFile() 方法,将提取的结果,写入到 clock 目录中 index.js的文件里面
    fs.writeFile(path.join(__dirname, './clock/index.js'), newJS, function (err) {
        if (err) return console.log("写入 CSS 样式失败!")
        console.log("写入样式文件成功")
    })
}

// 5.1 定义处理 HTML 样式的方法
function resolveHTML(val) {
    // 5.2 将字符串调用 replace 方法,把内嵌的 style 和 script 标签,替换为外联的 link 和 script 标签
    const newHTML = val.toString().replace(refStyle,'<link rel="stylesheet" href="./index.css">').replace(refScript,'<script src="./index.js"></script>')
    // 5.3 调用 fs.writeFile() 方法,将得出的结果,写入到 clock 目录中 index.html的文件里面
    fs.writeFile(path.join(__dirname, './clock/index.html'), newHTML, function (err) {
        if (err) return console.log("写入 HTML 样式失败!")
        console.log("写入样式文件成功")
    })
}

以上就是 node.js 中 path 的路径处理问题,不懂得也可以在评论区里问我,以后会持续发布一些新的功能,敬请关注。
我的其他文章:https://blog.csdn.net/weixin_62897746?type=blog

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清风 与我

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值