UNPKG

filecat

Version:
60 lines (58 loc) 2.64 kB
const path = require('path'); const nodeExternals = require('webpack-node-externals'); const webpack = require('webpack'); const TerserPlugin = require("terser-webpack-plugin"); const package_data = require("../../package.json") const {base_url} = require("./env"); const plugins = [ new webpack.DefinePlugin({ 'process.env.NODE_ENV': JSON.stringify('production'), 'process.env.version': JSON.stringify(package_data.version), 'process.env.base_url': JSON.stringify(base_url), // 'process.env.run_env': JSON.stringify("exe") // 必须用 JSON.stringify }), // new webpack.DefinePlugin({ // 'process.platform': JSON.stringify(process.platform) // 这里将 process.platform 替换为实际的值 在遇到动态打包的时候require 可以判断类型 函数内部的无法判断 // }), new webpack.IgnorePlugin({ resourceRegExp: /Debug/, }) ]; module.exports = { target: 'node', // 指定打包结果运行在node环境下 mode: 'production', // 或者 'production' entry: path.join(__dirname, "..", "..", "build", "server", "main", "server.js"), // 你的TypeScript入口文件路径 output: { path: path.resolve(__dirname, "..", "..", "build"), // 输出目录 filename: 'main.js', // 输出文件名 }, resolve: { extensions: ['.ts', '.js', '.node'], // 解析文件时自动补全的文件扩展名 }, module: { rules: [ { test: /\.node$|Addon$/, loader: 'node-loader', // 会拷贝.node 并改变require路径 到build目录下 但是如果 .node 有更新 他是不会不更新的需要先删除? } ] }, externalsPresets: { node: true }, externals: [ { '@aws-sdk/client-s3': 'S3', // 假设全局变量名为 S3 是 @aws-sdk/client-s3带 @符号的话会无法压缩 'cors':'commonjs cors' // 动态加载无法打包 如果需要可以使用 import "cors" // 'routing-controllers':'commonjs routing-controllers', // 有一些动态引入(他需要的动态引入也需要导入),或者含有.node(使用用户自己安装编译的版本) 无法被打包 直接忽略这个包 } ], // externals: [nodeExternals()], // 将所有的外部模块排除打包 plugins, optimization: { minimize: true, // 压缩Js代码 minimizer: [ new TerserPlugin({ // extractComments: true,//不将注释提取到单独的文件中 }), ], } };