webpack多页面配置3--打包相关node模块介绍
更新日期:
最近项目中需要搭建一个多页面的环境,包括本地路由服务和分页面打包。
本节实现单个页面或是完整页面的打包过程的过程。
npm模块
打包页面需要用到一些npm模块(需单独安装),这里我们简单介绍一下。
ora
模块
主要用来实现node.js
命令行环境的loading效果,和显示各种状态的图标等。
1 | const ora = require('ora') |
更多的选项,大家到官方说明上面看吧。
rimraf
模块
实现node.js
环境的UNIX命令rm -rf
。
1 | rimraf(f, [opts], callback) |
f
,可为glob
匹配规则的文件[opts]
,一些选项,具体可参考官方说明callback
,若执行过程中出错,则回调参数为error
如果大家用过shalljs
,这是一个node.js
环境的Unix shell
命令,里面当然已经包括rm
命令了。
chalk
模块
命令行输出各种样式的字符串。
- 使用方式
chalk.<style>[.<style>...](string, [string...])
1 | // 例如,红色带下划线的粗体字 |
node.js模块
介绍将使用到的node.js自带API和内置模块(无需安装)。
path
模块
path
模块提供了一些工具函数,用于处理文件与目录的路径。这是node.js
一个自带的模块。
path
模块的默认操作会根据Node.js
应用程序运行的操作系统的不同而变化。比如,当运行在Windows
操作系统上时,path
模块会认为使用的是Windows
风格的路径。
path.join([...paths])
使用平台特定的分隔符把全部给定的path
片段连接到一起,并规范化生成的路径。
这个大概是我们写webpack配置的时候,最常用的一个方法啦,像path.join(__dirname, 'src')
。
path.parse(path)
返回一个对象,对象的属性表示path
的元素。返回属性包括:dir
, root
, base
, name
, ext
。
path.format(pathObject)
会从一个对象返回一个路径字符串,与path.parse()
相反。
path.dirname(path)
返回一个path
的目录名,类似于Unix
中的dirname
命令。
process
模块
process
对象是一个global
(全局变量),提供有关信息,控制当前Node.js
进程。
作为一个对象,它对于Node.js
应用程序始终是可用的,故无需使用require()
。
process.execPath
返回启动Node.js
进程的可执行文件所在的绝对路径。
process.argv
process.argv
属性返回一个数组,这个数组包含了启动Node.js
进程时的命令行参数。第一个元素为process.execPath
。
如果需要获取argv[0]
的值请参见process.argv0
。第二个元素为当前执行的JavaScript文件路径,剩余的元素为其他命令行参数。
1 | // 运行以下命令,启动进程: |
process.env
process.env
属性返回一个包含用户环境信息的对象。
像我们经常看到生产环境process.env.NODE_ENV = 'production'
和开发环境process.env.NODE_ENV = 'dev'
。
- 输入流
process.stdin
和输出流process.stdout
process
还有更多的进程管理相关的方法和参数,大家可以参考官方说明。
结束语
本节主要介绍了后面打包页面时会使用到的一些node.js内置和依赖模块,包括终端输出样式、命令、path
、process
等。后面一节也会用到来进行页面的打包。
可参考代码github-vue-multi-pages,主要是这套环境使用在vue上的demo。
码生艰难,写文不易,给我家猪囤点猫粮了喵~
查看Github有更多内容噢:https://github.com/godbasin
更欢迎来被删的前端游乐场边撸猫边学前端噢
如果你想要关注日常生活中的我,欢迎关注“牧羊的猪”公众号噢