关于Node.js中path模块的resolve()和join()方法的比较,对照着总结看例子差很少之后在写模块的时候思路就能很清晰了
做用:path.resolve() 该方法将一些的 路径/路径段 解析为绝对路径。spa
语法:path.resolve([...paths])code
说明:字符串
例子:我当前的工做路径为/workspace/demo
string
console.log(path.resolve()) // returns /workspace/demo console.log(path.resolve('')) // returns /workspace/demo console.log(path.resolve(__dirname)) // returns /workspace/demo console.log(path.resolve('/img/books', '/net')) // returns '/net' console.log(path.resolve('img/books', '/net')) // returns '/net' console.log(path.resolve('img/books', './net')) // returns '/workspace/demo/img/books/net' console.log(path.resolve('/img/books', './net')) // returns '/img/books/net' console.log(path.resolve('/img/books', 'net')) // returns '/img/books/net' console.log(path.resolve('/img/books', '../net')) // returns '/img/net' console.log(path.resolve('src','/img/books', '../net')) // returns '/img/net' console.log(path.resolve('src','./img/books', '../net')) // returns '/workspace/demo/src/img/net' console.log(path.resolve('src','img/books', '../net')) // returns '/workspace/demo/src/img/net'
总结一下:参数从后向前,若字符以 / 开头,不会拼接到前面的路径;若以 ../ 开头,拼接前面的路径,可是不含前面一节的最后一层路径;若以 ./ 开头 或者没有符号 则拼接前面路径;console
做用:path.join()方法使用平台特定的分隔符把所有给定的 path 片断链接到一块儿,并规范化生成的路径。语法
语法:path.join([...paths])方法
说明:im
例子:总结
path.join('/img', 'book', 'net/abc', 'inter', '..'); // returns /img/book/net/abc console.log(path.join('/img/books', '../net')) // returns /img/net console.log(path.join('img/books', '../net')) // returns img/net console.log(path.join('/img/books', './net')) // returns /img/books/net console.log(path.join('img/books', './net')) // returns img/books/net console.log(path.join('/img/books', 'net')) // returns /img/books/net console.log(path.join('img/books', 'net')) // returns /img/books/net console.log(path.join('/img/books', '/net')) // returns /img/books/net console.log(path.join('img/books', '/net')) // returns img/books/net
总结一下 区别:join()只是拼接各个path片断,并不像resolve()同样除了拼接各个字段还拼接了工做目录的路径,其次若是以/
开头的字符串片断在join并不像resolve同样是只返回自身,还有就是..
同 ../
是一个意思都表明上一级目录demo