zoukankan      html  css  js  c++  java
  • node 学习笔记

    本文同步自我的个人博客:http://www.52cik.com/2015/12/04/learn-node-path.html

    path 模块是 node 用于整理、转换、合并路径的神器,只要是路径问题,都可以交给它处理。
    但它仅仅是处理路径字符串,而不会去坚持或处理文件。

    path.normalize 路径整理

    做项目时,往往都是基于相对路径,于是经常会出现类似这样的路径 path//upload/../file/./123.jpg
    当然这个是把所有坑都写到一起了,不过就算这样的路径,path.normalize 分分钟搞定。

    var path = require('path');
    
    var str = path.normalize('./path//upload/data/../file/./123.jpg');
    console.log(str); // path/upload/file/123.jpg
    

    path.join 拼接路径

    那些奇葩路径往往都是自己拼接导致的,如果用一些工具帮助我们处理这,就可以直接得到规范的路径了,而且不需要担心跨平台问题。这里的 path.join 就可以帮助我们生产跨平台,规范化的路径字符串。

    var path = require('path');
    
    var str = path.join('./path/./', './upload', '/file', '123.jpg');
    console.log(str); // path/upload/file/123.jpg
    
    var str = path.join('path', 'upload', 'file', '123.jpg');
    console.log(str); // path/upload/file/123.jpg
    
    var arr = ['path', 'upload', 'file', '123.jpg'];
    var str = path.join.apply(null, arr);
    console.log(str); // path/upload/file/123.jpg
    

    这个方法虽然方便,但是参数只能是字符串,否则会抛出错误(0.10以上版本)。

    path.resolve 绝对路径

    这个绝对路径操作,跟上面的不太一样,如果你懂命令行 cd 命令,那就秒懂了,否则需要花点时间多跑几个例子才能理解。这次直接上官方例子。

    path.resolve('foo/bar', '/tmp/file/', '..', 'a/../subfile');
    // 返回 /tmp/subfile
    

    相当于命令行下的

    cd foo/bar
    cd /tmp/file/
    cd ..
    cd a/../subfile
    pwd
    

    他的解析不是在是简单的拼接关系,而是类似 cd 命令的解析了。

    path.relative 相对路径

    有绝对就有相对,有时我们有两个绝对路径, 我们需要从中找出相对目录的起源目录。

    path.relative('/data/orandea/test/aaa', '/data/orandea/impl/bbb')
    // 返回 ../../impl/bbb
    

    path.dirname 文件路径

    根据一个文件或目录得到它所在的目录路径,这个很常用。

    var path = require('path');
    
    var str = path.dirname('path/upload/file/123.jpg');
    console.log(str); // path/upload/file
    
    var str = path.dirname(__filename); // 等价于 __dirname
    console.log(str, __dirname); // 当前文件所在目录
    

    path.basename 获取路径中的文件名

    确切的说是返回最后一个路径分割后面的文件名,不论是文件还是目录,第二个参数可以忽略文件后缀。

    var path = require('path');
    
    var str = path.basename('path/upload/file/123.txt.jpg');
    console.log(str); // 123.txt.jpg
    
    var str = path.basename('path/upload/file/123.txt.jpg', '.jpg');
    console.log(str); // 123.txt
    
    var str = path.basename('path/upload/file/123.txt.jpg', '.txt.jpg');
    console.log(str); // 123
    
    var str = path.basename('path/upload/file/');
    console.log(str); // file
    

    代码都是简单易懂的。

    path.extname 文件后缀

    确切说,就是返回最后一个 . 之后的字符串,没有则返回空。

    var path = require('path');
    
    var str = path.extname('path/upload/file/123.txt.jpg');
    console.log(str); // '.jpg'
    
    var str = path.extname('path/upload/file/123.txt');
    console.log(str); // '.txt'
    
    var str = path.extname('path/upload/file/');
    console.log(str); // ''
    

    path.parse 解析路径

    把一个路径解析为一个 {root:'', dir:'', base:'', ext:'', name:''} 这样的对象。
    有时候要获取文件名,文件后缀,文件目录,这样到省事了,直接搞定。上官方例子。

    path.parse('/home/user/dir/file.txt')
    // returns
    {
        root : "/",
        dir : "/home/user/dir",
        base : "file.txt",
        ext : ".txt",
        name : "file"
    }
    
    // windows
    path.parse('C:\path\dir\index.html')
    // returns
    {
        root : "C:\",
        dir : "C:\path\dir",
        base : "index.html",
        ext : ".html",
        name : "index"
    }
    

    path.format 生成路径

    正好跟 path.parse 相反,这个则是根据 {root:'', dir:'', base:'', ext:'', name:''} 这样的对象来生成字符串。上官方例子。

    path.format({
        root : "/",
        dir : "/home/user/dir",
        base : "file.txt",
        ext : ".txt",
        name : "file"
    })
    // returns
    '/home/user/dir/file.txt'
    

    其他属性

    还有一些属性,如 path.sep 不同平台下的文件路径分隔符,win 是 \,*nix 则是 /
    path.delimiter 字面解释,这才是分隔符,但这个往往是环境变量中出现的,win 是 ;,*nix 则是 :,你们懂的。

    还有两个奇葩属性,path.posixpath.win32 他们都包含上面这些方法属性,前者跨平台,后者只是win上。
    不知道为什么要单独搞两个这样的属性。

    好了,争取每天学习一点基础,只有把这些基础知识梳理一遍,才能更好的掌握 node。

  • 相关阅读:
    《新人口论》摘录
    中国历史上农村剩余劳动力的安置政策
    sql 善后处理的一些代码
    淘宝骗家实录
    什么决定着我们的工作
    【原创】打造具有EnableWindow功能的SPYXX
    文件被锁住删除不了的一种解决方法
    去除页面中所有的标记
    用动网论坛做BUG管理,感觉还不错
    同事刚告诉我一不错的东东VNN
  • 原文地址:https://www.cnblogs.com/52cik/p/learn-node-path.html
Copyright © 2011-2022 走看看