node环境打包js,webpack和rollup两个打包工具打包,能支持vue

引言

项目中经常用到共用的js,这里就需要用到共用js打包,这篇文章讲解两种打包方式,webpack打包和rollup打包两种方式

1、webpack打包js

1.1 在根目录创建 webpack.config.js,配置如下

bash 复制代码
const path = require('path');
module.exports = {
 entry: './index.js', 
 output:{
  filename:'index.js',
  path:path.resolve(__dirname,'dist'),
  library: 'myModule',
  libraryTarget:'umd'
 },
 // 以下代码为新添加代码
 module:{
  rules:[
   {
    test: /\.js$/, // 匹配所有 js 文件
    loader: 'babel-loader' // 使用 babel-loader 处理 js 文件
   },
  ]
 },
};

1.2 安装依赖包 package.json

npm install @babel/core @babel/preset-env babel-loader @babel/plugin-transform-runtime 这里用来将es6转成es5

npm install webpack webpack-cli

bash 复制代码
{
  "main": "index.js",
  "scripts": {
    "buildwebpack": "webpack"
  },
  "devDependencies": {
    "@babel/core": "^7.23.9",
    "@babel/preset-env": "^7.23.9",
    "babel-loader": "^9.1.3",
    "webpack": "^5.90.0",
    "webpack-cli": "^5.1.4"
  },
  "dependencies": {
    "@babel/plugin-transform-runtime": "^7.23.9"
  }
}

1.3 配置 babel.config.js

bash 复制代码
const presets = [
    [
        "@babel/env",
        {
            targets: {
                ie: "6",
                edge: "17",
                firefox: "60",
                chrome: "67",
                safari: "11.1"
            },
            //useBuiltIns: "usage",
            //corejs: "3", // <---  此处加个这个,就没有报错警告了

        },
    ],
];

module.exports = { presets,
    "plugins": ["@babel/transform-runtime"]
};

1.4 webpack 支持vue

"vue-loader": "^15.11.1",

"vue-template-compiler": "^2.6.12" //需要和vue版本一致

npm install vue-loader@15 vue-template-compiler@2 vue@2 css-loader

bash 复制代码
const path = require('path');
const {VueLoaderPlugin} = require('vue-loader')
module.exports = {
 entry: './index.js', 
 output:{
  filename:'index.js',
  path:path.resolve(__dirname,'dist'),
  library: 'myModule',
  libraryTarget:'umd'
 },
 // 以下代码为新添加代码
 module:{
  rules:[
   {
    test: /\.js$/, // 匹配所有 js 文件
    loader: 'babel-loader' // 使用 babel-loader 处理 js 文件
   },
   {
    test: /\.vue$/, 
    loader: 'vue-loader'
   },
//    { test: /\.css$/, 
//      use: ['style-loader','css-loader' ]
//    },
  ]
 },
 //需要注意的点:vue-loader 15版本需加入插件
 plugins: [
    new VueLoaderPlugin()
  ]
};

2、rollup 打包js

2.1 在根目录创建 rollup.config.js,配置如下

bash 复制代码
import babel from 'rollup-plugin-babel';
export default {
    input: 'index.js',
    output: {
        file: 'lib/index.js',
        format: 'cjs',
    },
    plugins: [ babel({
        runtimeHelpers: true, 
        presets: ["@babel/preset-env"],
    }) ],
};

2.2 安装依赖包 package.json

npm install @babel/core @babel/preset-env 这里用来将es6转成es5

npm install rollup rollup-plugin-babel

bash 复制代码
{
  "main": "index.js",
  "scripts": {
    "buildrollup": "rollup -c",
  },
  "devDependencies": {
    "@babel/core": "^7.23.9",
    "@babel/preset-env": "^7.23.9",
    "babel-loader": "^9.1.3"
  },
  "dependencies": {
    "@babel/plugin-transform-runtime": "^7.23.9",
    "rollup": "^2.79.1",
    "rollup-plugin-babel": "^4.4.0"
  }
}

2.4 rollup 打包vue

rollup-plugin-vue^5.1.9 + vue-template-compiler

rollup-plugin-postcss 识别css和预处理文件

npm install rollup-plugin-vue@5 vue-template-compiler rollup-plugin-postcss

bash 复制代码
export default {
    input: 'index.js',
    output: {
        file: 'lib/index.js',
        format: 'cjs',
    },
    plugins: [ babel({
        runtimeHelpers: true, 
        presets: ["@babel/preset-env"],
    }),
    vue2({
        css:true,
        compilerTemplate: true,
        preprocessStyles: true
    }) ],
};
相关推荐
冠希陈、2 分钟前
PHP 判断是否是移动端,更新鸿蒙系统
android·开发语言·php
HDO清风23 分钟前
CASIA-HWDB2.x 数据集DGRL文件解析(python)
开发语言·人工智能·pytorch·python·目标检测·计算机视觉·restful
2201_7569890923 分钟前
C++中的事件驱动编程
开发语言·c++·算法
会飞的战斗鸡29 分钟前
JS中的链表(含leetcode例题)
javascript·leetcode·链表
多米Domi01134 分钟前
0x3f 第48天 面向实习的八股背诵第五天 + 堆一题 背了JUC的题,java.util.Concurrency
开发语言·数据结构·python·算法·leetcode·面试
2301_8223776535 分钟前
模板元编程调试方法
开发语言·c++·算法
csbysj202038 分钟前
Python 循环嵌套
开发语言
测试_AI_一辰41 分钟前
Agent & RAG 测试工程05:把 RAG 的检索过程跑清楚:chunk 是什么、怎么来的、怎么被命中的
开发语言·人工智能·功能测试·自动化·ai编程
Coding茶水间43 分钟前
基于深度学习的输电电力设备检测系统演示与介绍(YOLOv12/v11/v8/v5模型+Pyqt5界面+训练代码+数据集)
开发语言·人工智能·深度学习·yolo·目标检测·机器学习
清风~徐~来1 小时前
【视频点播系统】BRpc 介绍及使用
开发语言