『手撕Vue-CLI』获取下载目录

开篇

在上一篇文章中,简单的对 Nue-CLI 的代码通过函数柯里化优化了一下,这一次来实现一个获取下载目录的功能。

背景

在 Nue-CLI 中,我现在实现的是 create 指令,这个指令本质就是首先拿到模板名称和版本号之后,然后去进行下载对应的模板,关于下载那么肯定要面临的问题就是如何下载?下载到什么地方?

官方的 Vue-CLI 会先将模板下载到 用户目录 中,然后再拷贝到 执行指令的目录 中。

那么官方为什么要先下载到用户目录中呢?

因为下载好的模板可能还需要进行一些其它操作,例如:修改文件内容,删除文件等等。

好那么开始实现获取下载目录的功能。

实现

先去当前本机的用户目录进行查看一下,看看是什么样子的,先进入到 C 盘,然后找到用户目录:

再找到自己的用户名:

在自己的用户名文件夹当中,这个目录就是所说的用户目录,一般新电脑的设置不会开启显示隐藏的项目,如何开启?

点击显示隐藏的项目,然后就可以看到隐藏的项目了,什么是隐藏的项目呢?就是以 . 开头的项目,例如 .vscode.git 等等。

在里面就会存在使用 Vue-CLI 所拉取的模板,我这里因为是新电脑,我点进去会发现没有存在,但是经过我这些内容的介绍我想告诉大家的是,如何找到自己电脑上的用户目录。

好了,接下来就是实现获取下载目录的功能了,在 Node.js 中有一个模块叫做 os,这个模块可以获取到一些系统的信息,例如:用户目录,操作系统等等。

通过 process.env,可以获取当前电脑的环境变量,先来简单的打印看一下输出什么内容:

console.log(process.env);

通过观察控制台的输出结果发现一个 USERPROFILE 的环境变量,这个环境变量就是用户目录,好,接下来就好办了。

windows 的获取方式已经得知了,那么 mac 呢,所以这里就要区分一下平台,该如何进行区分呢?

这里也可以采用 process 模块,通过 process.platform 方法来获取当前系统的平台,windows 是 win32,mac 是 darwin,控制台打印一下看看:

console.log(process.platform);

知道了这些内容就够编写代码的知识储备,代码如下:

const currentPlatformKey = process.platform === 'win32' ? 'USERPROFILE' : 'HOME';
const downloadDirPath = `${process.env[currentPlatformKey]}\\.nue-template`;
console.log(downloadDirPath);

代码很简单其实就是三行代码,首先是根据当前的平台来获取对应的环境变量,如果是 windows 那么就是 USERPROFILE,如果是 mac 那么就是 HOME,这样一来就可以得出不同平台的用户目录地址,在从 process.env 中获取到对应的环境变量,然后拼接上 .nue-template 就是下载目录的地址了。

最后将这个地址返回出去,这样就可以在后续的代码中使用了。

posted @   BNTang  阅读(149)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
历史上的今天:
2023-06-01 常见的for循环优化方式
  1. 1 总会有人离开 王巨星
  2. 2 月亮 孟凡明
  3. 3 迟里乌布
  4. 4 我只能离开 颜人中
  5. 5 达尔文 蔡健雅
  6. 6 夜色滚烫 叶明净
  7. 7 你的星环 路飞文
  8. 8 不再说话 三块木头
  9. 9 黄昏 粥粥和小伙/粥粥
  10. 10 爱不单行 刘大拿
  11. 11 心动贩卖机 PIggy
  12. 12 别来无恙 苏星婕
  13. 13 我们的歌 刘大拿
  14. 14 一直很安静 王贰浪
  15. 15 去有风的地方 清音
  16. 16 雪 Distance Capper/罗言
  17. 17 坏女孩 徐良/小凌
  18. 18 乐园 沧桑Cang333/虎皮蛋/曲甲
  19. 19 Ayo(Explicit) Chris Brown/Tyga
  20. 20 我的美丽feat.海洋Bo 海洋Bo/高睿
  21. 21 世事可爱 粥粥和小伙/粥粥
  22. 22 我记得 赵雷
  23. 23 我想牵着你的手 许嵩
  24. 24 人们都不懂 刘诺然
  25. 25 寻一个你(电视剧《苍兰诀》温情主题曲) TTTTTeehom
  26. 26 子莫格尼 杉和
  27. 27 Cat Cafe Shoffy
  28. 28 风停了雨停了我们还拥抱着 Superluckyqi
  29. 29 寂寞沙洲冷 于潼
  30. 30 三国恋 王巨星
  31. 31 达尔文 林俊杰
  32. 32 有些 颜人中
  33. 33 小模样 张小只ya
  34. 34 是否 程响
  35. 35 楼顶上的小斑鸠 队长
  36. 36 笑场 薛之谦
  37. 37 还是分开 张叶蕾
  38. 38 修炼爱情 林俊杰
  39. 39 二零三 毛不易
  40. 40 雅俗共赏 许嵩
  41. 41 Serendipity 古瑞斯Graps/Zakiya晴子
  42. 42 就让这大雨全都落下·2023 刘大拿
  43. 43 老男孩 筷子兄弟
  44. 44 有何不可 许嵩
  45. 45 缓缓 杜宣达
  46. 46 好久不见 陈奕迅
  47. 47 爱的魔法(Cover 金莎) 封茗囧菌
  48. 48 在你的身边 盛哲
  49. 49 带我去找夜生活 告五人
  50. 50 假面舞会 很美味
  51. 51 STAY The Kid LAROI/Justin Bieber
  52. 52 我好想睡觉的 无敌西红柿
  53. 53 日不落(温柔版)
  54. 54 恋爱画板 锦零
  55. 55 7710 好乐无荒/尹露浠
  56. 56 给你呀(又名:for ya) 蒋小呢
  57. 57 Love Story Taylor Swift
  58. 58 Plain Jane(Remix 13z) 鱼幼微
  59. 59 晚风 7opy/BT07
  60. 60 拜托 孙晨
  61. 61 乌梅子酱 李荣浩
  62. 62 南半球与北海道 范倪Liu
  63. 63 星河万里 Rom邢锐
楼顶上的小斑鸠 - 队长
00:00 / 00:00
An audio error has occurred, player will skip forward in 2 seconds.

作词 : 队长

作曲 : 队长

编曲 : 队长

作词:队长

作曲:队长

制作人:队长

要疯了又翻到你紫色的外套

舍不得丢掉怕你回来冷到

霓虹的街 慌乱一瞥

再也没有忘掉雨中的夜

我也不会奢求你回来

我也不想和你 say goodbye

我也不会奢求你回来

只是思念汹涌又难捱(I still want you to stay)

没能出现在你的眼前

我的悲伤被你藏在深夜

多少和你在一起的瞬间

毁灭

我的确想让你回来(I don’t wanna go)

回来(wanna go)

不要再次离开(I don’t wanna go)

离开 离开(wanna go)

What can I do

What can I do

What can I do

我只能说我是爱情里的废材

我只能说我曾以为我看到你就以为你是我未来

想你就颓废 流泪 烂理由一大堆

拨打你的电话的时候会烂醉

告诉我要往哪飞 我时刻都在准备

我再也不想自己有任何的机会后悔

放开了手 you gotta go

我不是那种荒唐的人

再说次别走

记忆不断的在眼前穿插

安心地摸着你脸颊

你是否也会在深夜里想起我那么一刹那

I’m on the way I’m on the way

一个人睡 一个人醉

不知道为什么能这样卸下了我的防备

这是为什么会 比他 比他

比他会更好

悲伤 当然

不就是你一句滚蛋

无话 不谈

变成了各自另一半

我们 相反

注定会被对方纠缠

当然 当然 当然

I don’t wanna go, wanna go 不想你离开

其实我最在意的是你能释怀

I don’t wanna go, wanna go 我自己活该

其实我最在意的只是你的爱

悲伤 当然

不就是你一句滚蛋

无话 不谈

变成了各自另一半

我们 相反

注定会被对方纠缠

当然 当然 当然

是我没种 让你独自一人悲痛

我们始终 却都忍不住了眼红

谁懂 谁能 听懂

没能出现在你的眼前

我的悲伤被你藏在深夜

多少和你在一起的瞬间

毁灭

我的确想让你回来(I don’t wanna go)

回来(wanna go)

不要再次离开(I don’t wanna go)

离开 离开(wanna go)

What can I do

编曲:任柯

录音:队长

Vocal Production:队长

吉他:任柯

贝斯:任柯

和声编写:队长

和声:队长

混音:队长

音频编辑: 叶靖棠

母带:全相彦

企划&统筹:万青青

营销:Hot Cake Studio & Believe Artist Service

点击右上角即可分享
微信分享提示