您好,欢迎来到爱够旅游网。
搜索
您的当前位置:首页使用webpack打包koa2 框架app

使用webpack打包koa2 框架app

来源:爱够旅游网

四: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即可。

Copyright © 2019- igbc.cn 版权所有 湘ICP备2023023988号-5

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务