node后端项目使用webpack打包教程,target: “node“

node后端项目使用webpack打包教程

安装webpack webpack-cli

bash 复制代码
pnpm add webpack webpack-cli -D

webpack 能够为多种环境 或 target构建编辑。想要理解什么是target的详细信息。

taget string [string] false

告知 webpack 为目标(target)指定一个环境。默认值为 browserslist,如果没有找到 browserslist 的配置,则默认为 web

选项 描述
async-node 编译为类 Node.js 环境可用(使用 fs 和 vm 异步加载分块)
electron-main 编译为 Electron 主进程。
electron-renderer 编译为 Electron 渲染进程,
使用 JsonpTemplatePlugin,FunctionModulePlugin 来为浏览器环境提供目标,使用 NodeTargetPlugin 和 ExternalsPlugin
为 CommonJS 和 Electron 内置模块提供目标。
electron-preload 编译为 Electron 渲染进程,
使用 NodeTemplatePlugin 且 asyncChunkLoading 设置为 true ,FunctionModulePlugin 来为浏览器提供目标,使用 NodeTargetPlugin 和 ExternalsPlugin 为 CommonJS 和 Electron 内置模块提供目标。
node 编译为类 Node.js 环境可用(使用 Node.js require 加载 chunks)
node-webkit 编译为 Webkit 可用,并且使用 jsonp 去加载分块。支持 Node.js 内置模块和 nw.gui
导入(实验性质)
nwjs[[X].Y] 等价于 node-webkit
web 编译为类浏览器环境里可用 (默认)
webworker 编译成一个 WebWorker
esX 编译为指定版本的 ECMAScript。例如,es5,es2020
browserslist 从 browserslist-config 中推断出平台和 ES 特性 (如果 browserslist 可用,其值则为默认)

创建webpack.conf.js配置文件

js 复制代码
const path = require(path)
const nodeExternals = require("webpack-node-externals")

module.exports = {
  target: "node",
  entry: "./src/index.js",
  ouptput: {
    path: path.resolve(__dirname, "dist")
  },
  externals: [nodeExternals()],
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        use: {
          loader: 'babel-loader',
          options: {
            presets: ['@babel/preset-env']
          }
        }
      }
    ]
  }
}

创建.babelrc

gson 复制代码
{
  "preset":["@babel/preset-env"]
}

下载依赖

bash 复制代码
pnpm add babel @babel/preset-env webpack-node-externals -D

修改package.json

json 复制代码
...
"scripts": {
  ...
  "build": "webpack --mode production"
}
...

直接起飞

bash 复制代码
pnpm build
相关推荐
小满zs6 分钟前
Next.js第十四章(缓存策略)
前端
低保和光头哪个先来16 分钟前
CSS+JS实现单例老虎机切换图片动画
前端·javascript·css
IT_陈寒24 分钟前
Vue3性能优化实战:这5个技巧让我的应用加载速度提升了40%
前端·人工智能·后端
小小鸟00831 分钟前
Vue响应式原理
前端·javascript·vue.js
lee57633 分钟前
鄙人的 Vue 3.0 商业级开源甘特图已经发布到 npm
前端·vue.js·npm·开源·甘特图
前端老曹36 分钟前
vue3 三级路由无法缓存的终终终终终终极解决方案
前端·javascript·vue.js
1024小神37 分钟前
uniapp + vue3 + scss 定义全局样式变量,并使用
前端·uni-app·scss
顾安r38 分钟前
12.17 脚本网页 创意导航
java·linux·前端·游戏·html
Q_Q51100828540 分钟前
小程序基于Java Web的健身房管理系统设计和开发
java·前端·小程序
qq_3482318540 分钟前
面向初学者到进阶者的 Node.js 学习指南
node.js