使用webpack打包koa2 框架app
以前在用koa写server的时候,发布简直是噩梦。需要将src里面的全部文件都覆盖掉,config配置文件也要覆盖,稍有不慎就会线上报各种各样的问题,然后就得回退,本地调好在发布。偶然看见一篇文章讲 如何使用webpack打包koa app ,惊为天人,原来webpack也能打包后台。这在以前想都没想过。
关键问题
一:所有node_modules里的模块都不进行打包
webpack的核心功能是将引用的各个模块打到一个文件里,并会将各种规范的模块进行统一的模块化处理(webpack规范)。
然而node中包含大量的fs、path操作,这些fs和path操作在打包完成后将没有操作对象,还会报出很多各样的错误。
所以使用webpack打包的核心就是拒绝打包一切node_modules里的模块,只是将相对路径引用的文件打包到一个文件里。恰巧我们发现webapck提供externals属性来排除掉不需要打包的模块。
再深入点我们可以发现:像webpack、nodemon、babel-preset-env这样的模块是app开发环境依赖的包,我们的程序里根本不会require这些模块。
综上可以发现:我们只将所有require到的包排除掉就可以了,这个模块对应的也就是package.json里dependencies下的模块。有关dependencies和devdependencies的区别要理解好。
因此我们可以使用externals-dependencies这个插件配合externals属性实现dependencies的排除工作。
代码:
const webpack = require('webpack'); const _externals = require('externals-dependencies') module.exports = { ... externals: _externals(), ... }
二:target指向node
官方文档:编译为类 node.js 环境可用(使用 node.js require 加载 chunk)
代码:
target: 'node',
三:增加node配置
官方文档:这些选项可以配置是否 polyfill 或 mock 某些 node.js全局变量和模块。这可以使最初为 node.js 环境编写的代码,在其他环境(如浏览器)中运行。
代码:
node: {
console: true,
global: true,
process: true,
buffer: true,
__filename: true,
__dirname: true,
setimmediate: true,
path: true
},
四:babel配置
为了兼容低版本的node不原生支持async/await的问题。这里babel我使用了babel-preset-env{"modules": false}的配置。此配置会将es6语法转为es5语法,例如let、const转为var。
同时将所有的async/await函数也转成了polyfill里定义的_asynctogenerator函数。
function _asynctogenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
其实是使用promise实现了async函数的功能。
当然这个函数在运行时还需要regeneratorruntime函数。所以我在全局引入了babel-polyfill来提供regeneratorruntime函。
注:如果你的node版本很高且原生支持async/await,大可将babel-preset-env和babel-polyfill省略掉
代码:
const path = require('path'); const webpack = require('webpack'); const _externals = require('externals-dependencies') module.exports = { entry: { app: [ // 如果polyfill放在这里,打包的时候将不会被external,必须在js里require才能有效external // 'babel-polyfill', './src/index.js' ] }, output: { path: path.resolve(__dirname), filename: '[name].js' }, resolve: { extensions: [".js"] }, target: 'node', externals: _externals(), context: __dirname, node: { console: true, global: true, process: true, buffer: true, __filename: true, __dirname: true, setimmediate: true, path: true }, module: { rules: [ { test: /\.js/, use: ['babel-loader'] } ] }, plugins: [ new webpack.defineplugin({ 'process.env': { node_env: '"development"' } }), ] }
部署
经过打包,部署的时候就方便多了,只需要将package.json、app.js、以及view里的html部署上线就好了。然后在服务器上执行
1. npm install
2. npm run for
然后server就后台运行了。如果需要更新发布,只需要本地重新npm run dev或npm run build打好包,拖到服务器覆盖app.js即可。
上一篇: NW.js 简介与使用方法
推荐阅读
-
详解如何使用webpack打包Vue工程
-
vue解决使用webpack打包后keep-alive不生效的方法
-
新手快速上手webpack4打包工具的使用详解
-
基于webpack实现多html页面开发框架八 html引入图片打包和公共页面模块复用
-
详解使用mocha对webpack打包的项目进行"冒烟测试"的大致流程
-
使用webpack和rollup打包组件库的方法
-
详解Vue webapp项目通过HBulider打包原生APP(vue+webpack+HBulider)
-
解决vue 项目使用webpack打包后,直接打开dist文件夹下的index.html页面空白的问题
-
使用webpack打包koa2 框架app
-
使用webpack打包图片