使用JavaScript实现node.js中的path.join方法


Posted in Javascript onAugust 12, 2018

Node.JS中的 path.join 非常方便,能直接按相对或绝对合并路径,使用: path.join([path1], [path2], [...]),有时侯前端也需要这种方法,如何实现呢?

其实直接从 node.js 的 path.js 拿到源码加工一下就可以了:

1. 将 const 等 es6 属性改为 var,以便前端浏览器兼容
2. 添加一个判断路戏分隔符的变量 sep,即左斜杠还是右斜杠,以第一个路戏分隔符为准
3. 将引用的变量和函数放到一个文件里就可以了:

Path 的源码: https://github.com/nodejs/node/blob/master/lib/path.js

var CHAR_FORWARD_SLASH = 47
var CHAR_BACKWARD_SLASH = 92
var CHAR_DOT = 46
function isPathSeparator(code) {
 return code === CHAR_FORWARD_SLASH || code === CHAR_BACKWARD_SLASH;
}
function isPosixPathSeparator(code) {
 return code === CHAR_FORWARD_SLASH;
}
function normalize(path) {
 if (path.length === 0)
  return '.';
 var isAbsolute = path.charCodeAt(0) === CHAR_FORWARD_SLASH;
 var trailingSeparator =
  path.charCodeAt(path.length - 1) === CHAR_FORWARD_SLASH;
 // Normalize the path
 path = normalizeString(path, !isAbsolute, '/', isPosixPathSeparator);
 if (path.length === 0 && !isAbsolute)
  path = '.';
 if (path.length > 0 && trailingSeparator)
  path += '/';
 if (isAbsolute)
  return '/' + path;
 return path;
}
function normalizeString(path, allowAboveRoot, separator, isPathSeparator) {
 var res = '';
 var lastSegmentLength = 0;
 var lastSlash = -1;
 var dots = 0;
 var code;
 for (var i = 0; i <= path.length; ++i) {
  if (i < path.length)
   code = path.charCodeAt(i);
  else if (isPathSeparator(code))
   break;
  else
   code = CHAR_FORWARD_SLASH;
  if (isPathSeparator(code)) {
   if (lastSlash === i - 1 || dots === 1) {
    // NOOP
   } else if (lastSlash !== i - 1 && dots === 2) {
    if (res.length < 2 || lastSegmentLength !== 2 ||
      res.charCodeAt(res.length - 1) !== CHAR_DOT ||
      res.charCodeAt(res.length - 2) !== CHAR_DOT) {
     if (res.length > 2) {
      const lastSlashIndex = res.lastIndexOf(separator);
      if (lastSlashIndex !== res.length - 1) {
       if (lastSlashIndex === -1) {
        res = '';
        lastSegmentLength = 0;
       } else {
        res = res.slice(0, lastSlashIndex);
        lastSegmentLength = res.length - 1 - res.lastIndexOf(separator);
       }
       lastSlash = i;
       dots = 0;
       continue;
      }
     } else if (res.length === 2 || res.length === 1) {
      res = '';
      lastSegmentLength = 0;
      lastSlash = i;
      dots = 0;
      continue;
     }
    }
    if (allowAboveRoot) {
     if (res.length > 0)
      res += `${separator}..`;
     else
      res = '..';
     lastSegmentLength = 2;
    }
   } else {
    if (res.length > 0)
     res += separator + path.slice(lastSlash + 1, i);
    else
     res = path.slice(lastSlash + 1, i);
    lastSegmentLength = i - lastSlash - 1;
   }
   lastSlash = i;
   dots = 0;
  } else if (code === CHAR_DOT && dots !== -1) {
   ++dots;
  } else {
   dots = -1;
  }
 }
 return res;
}
function join() {
 if (arguments.length === 0)
  return '.';
 var sep = arguments[0].indexOf('/') > -1 ? '/' : '\\'
 var joined;
 var firstPart;
 for (var i = 0; i < arguments.length; ++i) {
  var arg = arguments[i];
  if (arg.length > 0) {
   if (joined === undefined)
    joined = firstPart = arg;
   else
    joined += sep + arg;
  }
 }
 if (joined === undefined)
  return '.';
 var needsReplace = true;
 var slashCount = 0;
 if (isPathSeparator(firstPart.charCodeAt(0))) {
  ++slashCount;
  var firstLen = firstPart.length;
  if (firstLen > 1) {
   if (isPathSeparator(firstPart.charCodeAt(1))) {
    ++slashCount;
    if (firstLen > 2) {
     if (isPathSeparator(firstPart.charCodeAt(2)))
      ++slashCount;
     else {
      // We matched a UNC path in the first part
      needsReplace = false;
     }
    }
   }
  }
 }
 if (needsReplace) {
  // Find any more consecutive slashes we need to replace
  for (; slashCount < joined.length; ++slashCount) {
   if (!isPathSeparator(joined.charCodeAt(slashCount)))
    break;
  }
  // Replace the slashes if needed
  if (slashCount >= 2)
   joined = sep + joined.slice(slashCount);
 }
 return normalize(joined);
}

使用:

join('../var/www', '../abc')
> "../var/abc"
join('../var/www', '\abc')
../var/www/abc

总结

以上所述是小编给大家介绍的使用JavaScript实现node.js中的path.join方法,希望对大家有所帮助,如果对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
javascript实现倒计时N秒后网页自动跳转代码
Dec 11 Javascript
javascript实现字符串反转的方法
Feb 05 Javascript
js实现大转盘抽奖游戏实例
Jun 24 Javascript
JS提交form表单实例分析
Dec 10 Javascript
jQuery配合coin-slider插件制作幻灯片效果的流程解析
May 13 Javascript
js计算系统当前日期是星期几的方法
Jul 14 Javascript
javascript 中的console.log和弹出窗口alert
Aug 30 Javascript
windows下vue-cli及webpack搭建安装环境
Apr 25 Javascript
浅谈Angular 中何时取消订阅
Nov 22 Javascript
vue router+vuex实现首页登录验证判断逻辑
May 17 Javascript
移动端H5页面返回并刷新页面(BFcache)的方法
Nov 06 Javascript
javascript读取本地文件和目录方法详解
Aug 06 Javascript
在小程序中集成redux/immutable/thunk第三方库的方法
Aug 12 #Javascript
Vue实现左右菜单联动实现代码
Aug 12 #Javascript
Vue中的v-for循环key属性注意事项小结
Aug 12 #Javascript
vue实现商品加减计算总价的实例代码
Aug 12 #Javascript
Vue.js中使用iView日期选择器并设置开始时间结束时间校验功能
Aug 12 #Javascript
深入理解Vue父子组件生命周期执行顺序及钩子函数
Aug 12 #Javascript
VUE在for循环里面根据内容值动态的加入class值的方法
Aug 12 #Javascript
You might like
php制作动态随机验证码
2015/02/12 PHP
PHP整合PayPal支付
2015/06/11 PHP
Yii2实现自定义独立验证器的方法
2017/05/05 PHP
PHP后端银联支付及退款实例代码
2017/06/23 PHP
PHP实现的DES加密解密类定义与用法示例
2020/11/02 PHP
ASP.NET jQuery 实例5 (显示CheckBoxList成员选中的内容)
2012/01/13 Javascript
从零学JSON之JSON数据结构
2014/05/19 Javascript
js实现简单折叠、展开菜单的方法
2015/08/28 Javascript
js计算文本框输入的字符数
2015/10/23 Javascript
js实现网页收藏功能
2015/12/17 Javascript
jQuery语法小结(超实用)
2015/12/31 Javascript
AngularJS指令与控制器之间的交互功能示例
2016/12/14 Javascript
简单的渐变轮播插件
2017/01/12 Javascript
实例分析nodejs模块xml2js解析xml过程中遇到的坑
2017/03/18 NodeJs
JavaScript通过mouseover()实现图片变大效果的示例
2017/12/20 Javascript
详解Node.js一行命令上传本地文件到服务器
2019/04/22 Javascript
nodejs语言实现验证码生成功能的示例代码
2019/10/13 NodeJs
js实现一款简单踩白块小游戏(曾经很火)
2019/12/02 Javascript
vue-socket.io跨域问题有效解决方法
2020/02/11 Javascript
微信小程序云函数添加数据到数据库的方法
2020/03/04 Javascript
JavaScript 实现下雪特效的示例代码
2020/09/09 Javascript
python打开网页和暂停实例
2014/09/30 Python
Python的ORM框架中SQLAlchemy库的查询操作的教程
2015/04/25 Python
Python编程实现的简单神经网络算法示例
2018/01/26 Python
django中使用Celery 布式任务队列过程详解
2019/07/29 Python
对django 模型 unique together的示例讲解
2019/08/06 Python
Python新建项目自动添加介绍和utf-8编码的方法
2020/12/26 Python
浅谈盘点5种基于Python生成的个性化语音方法
2021/02/05 Python
澳大利亚音乐商店:Bava’s Music City
2019/05/05 全球购物
Farfetch台湾官网:奢侈品牌时尚购物平台
2019/06/17 全球购物
Ref与out有什么不同
2012/11/24 面试题
项目建议书怎么写
2014/05/15 职场文书
贸易经济专业自荐书
2014/06/29 职场文书
教师自我剖析材料(四风问题)
2014/09/30 职场文书
信贷客户经理岗位职责
2015/04/09 职场文书
Python中递归以及递归遍历目录详解
2021/10/24 Python