vue.config.js自定义插件和自定义vue-cli-service命令

自己做记录

自定义插件

define2.js

javascript 复制代码
class TestDefine{
    constructor(){
        // this.name = 'test';
    }
    apply(compiler) {
        console.log("进入")
        compiler.hooks.environment.tap('pluginName', (compilation) => {
            process.UNI_SCRIPT_DEFINE={
                "WOBUGUAN":true,
                "WOBUGUAN2":false
                };
            console.log('webpack 构建正在启动=========!');
          });
          compiler.hooks.beforeRun.tap('pluginName2', (compilation) => {
            process.UNI_SCRIPT_DEFINE={
                    "WOBUGUAN":true,
                    "WOBUGUAN2":false
                    };
            console.log('webpack beforeRun=========!');
          });
          
        // compiler.hooks.compilation.tap('compilation',compilation => {
        //     console.log("进入compilation-----------");
        //     // 在环境变量中添加一个新属性
        //   process.UNI_SCRIPT_DEFINE={
        //     "WOBUGUAN":true,
        //     "WOBUGUAN2":false
        //     };
        // })
        // compiler.hooks.environment.tap('MyPlugin', () => {
        //   // 在环境变量中添加一个新属性
        //   process.UNI_SCRIPT_DEFINE={
        //     "WOBUGUAN":true,
        //     "WOBUGUAN2":false
        //     };
        // });
    }
}
module.exports=TestDefine;

参考compiler 钩子 | webpack 中文文档 | webpack中文文档 | webpack中文网

vue.config.js

javascript 复制代码
let TestDefine=require("./define2.js")
console.log("vue.config.js")
const { DefinePlugin } = require('webpack');
const ProcessOverridePlugin = require('./ProcessOverridePlugin'); // 调整路径以匹配实际位置
module.exports={
    configureWebpack:{
        plugins:[
            new TestDefine(),
            new DefinePlugin({
            // 使用 DefinePlugin 定义 process 对象,以便在编译时替换
                'process.env': JSON.stringify(process.env),
            }),
        ]
    },
}

自定义vue-cli-service命令

看的这篇文章

vue-cli 3学习之vue-cli-service插件开发(注册自定义命令)-CSDN博客

package.json

javascript 复制代码
{
  "name": "uniapp",
  "version": "0.1.0",
  "private": true,
  "vuePlugins": {
    "service": [
      "./vue-cli-plugin-test"
    ]
  },
    "scripts": {
    "build:h5": "cross-env NODE_ENV=production UNI_PLATFORM=h5 vue-cli-service testdefine && vue-cli-service uni-build",
    }
}

vue.config.js

javascript 复制代码
module.exports={
    pluginOptions: {
        test: {
          // vue-cli-plugin-test 插件可以作为 `projectOptions.pluginOptions.test` 访问这些选项,其他插件也可以拿到
          param: '传参内容'
        }
    }
}

vue-cli-plugin-test.js

javascript 复制代码
module.exports = (api, projectOptions) => {
    api.registerCommand('test', {
        description: 'test plugin for vue cli 3',
        usage: 'vue-cli-service test',
        options: {}
    }, (args) => {
        // 输出传入的参数
        console.log('watch 命令注册成功')
        // console.log(projectOptions.pluginOptions.test.param,"+================test")
    })
}
相关推荐
柳杉几秒前
使用three.js搭建3d隧道监测-2
前端·javascript·数据可视化
lynn8570_blog13 分钟前
低端设备加载webp ANR
前端·算法
LKAI.34 分钟前
传统方式部署(RuoYi-Cloud)微服务
java·linux·前端·后端·微服务·node.js·ruoyi
刺客-Andy1 小时前
React 第七十节 Router中matchRoutes的使用详解及注意事项
前端·javascript·react.js
前端工作日常1 小时前
我对eslint的进一步学习
前端·eslint
禁止摆烂_才浅2 小时前
VsCode 概览尺、装订线、代码块高亮设置
前端·visual studio code
程序员猫哥2 小时前
vue跳转页面的几种方法(推荐)
前端
代码老y3 小时前
十年回望:Vue 与 React 的设计哲学、演进轨迹与生态博弈
前端·vue.js·react.js
一条上岸小咸鱼3 小时前
Kotlin 基本数据类型(五):Array
android·前端·kotlin
zzywxc7873 小时前
详细探讨AI在金融、医疗、教育和制造业四大领域的具体落地案例,并通过代码、流程图、Prompt示例和图表等方式展示这些应用的实际效果。
开发语言·javascript·人工智能·深度学习·金融·prompt·流程图