ant脚本打包缺失html文件,前端自动分环境打包(vue和ant design)

本文介绍了如何在AntDesign和Vue项目中实现自动分环境打包,通过使用roadhog和cross-env来配置不同的环境变量,确保在打包时不会混淆测试和生产环境。在AntDesign项目中,利用roadhog的define配置和环境变量实现区分;而在Vue项目中,通过创建test.env.js文件,结合cross-env设置命令行参数,修改webpack配置文件以读取不同环境的配置,并调整打包命令。这样,开发者可以在打包时明确当前环境,降低错误推送的风险。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

现实中的问题:有时候版本上线的时候,打包时忘记切换环境,将测试包推上正式服务器,那你就会被批了。

期望:在写打包的命令行的时候就觉得自己在打包正式版本,避免推包时候的,不确信自己的包是否正确。

既然有了期望,那么就要开始百度如何去实现呢。

下面先开始介绍ant design的方法:

ant design的打包工具是roadhog,那么从roadhog下手。

在roadhog文档中,发现define的配置可以传递给代码。

8d6536071c02be52fbc4d74a6d5c6f9a.png

在ant design pro的issue中搜索中,发现环境变量的配置。

我这也不啰嗦了,直接贴代码了

868e4ed88325f9335c5c26b50d82e832.png

4f2396db4a748419972229cc6b885d26.png

那么介绍完ant disign的,开始介绍vue的吧

首先介绍下用的包吧,cross-env是为了解决跨平台的包,可以是命令行在window和mac上都可以使用。

第一步:

npm i --save-dev cross-env

第二步:

在根目录下的config下:新建一个test.env.js文件,对标已存在的prod.env.js的文件

‘use strict‘module.exports={

NODE_ENV:‘"test"‘}

在同级目录下的index.js中

c41a1d79721547755316f90dbff8303e.png

红色框的是新加的,在build对象中同样加入这两行代码,为了让在本地开发也可以切换正式测试的环境。

第三步

在根目录build文件夹下的的webpackage.prod.conf.js和webpackage.dev.conf.js文件中,获取刚才配置的test.env.js和prod.env.js

具体操作如下:

//const env = require(‘../config/prod.env‘) 注释这行原本的代码

const env = config.build[process.env.env_config+‘Env‘] //新加这行获取js的代码

newwebpack.DefinePlugin({‘process.env‘: env //将获取的js,放入process.env

}),

同级目录下build.js

//注释掉这行代码//process.env.NODE_ENV = ‘production‘

//修改spinner的定义//const spinner = ora(‘building for production...‘)

var spinner = ora(‘building for‘ + process.env.NODE_ENV + ‘of‘ + process.env.env_config+ ‘mode...‘ )

第四步:

设置打包命令行和起本地服务的命令行

"dev:test": "cross-env NODE_ENV=development env_config=test webpack-dev-server --inline --progress --config build/webpack.dev.conf.js","dev:prod": "cross-env NODE_ENV=development env_config=prod webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",

"build:test": "cross-env NODE_ENV=production env_config=test node build/build.js","build:prod": "cross-env NODE_ENV=production env_config=prod node build/build.js",

第五部

在代码获取值

console.log(process.env);

以上就介绍完自动分环境打包

原文:https://www.cnblogs.com/tzzf/p/10054763.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值