美洲杯赌球基于vue cli 通过命令行传参实现多环境

2019-07-27 20:01 来源:未知

npm run serve -sit //本地开发中使用sit环境

这里提示我们存在的第一个问题是没有配置webpack的mode选项,默认有production和development两种模式可以设置,因此我们尝试设为development模式,在命令行输入:

npm run build -local //打包后使用本地环境

翻译成中文:

你运行 npm run test 得到的就是test (我没试过)

二、创建项目

我们首先在根目录下面创建一个vue.config.js文件,如图

注意:本文并不是直接把正确步骤放上去,而是分析了各种报错情况及原因,文章的步骤显得绕弯子。如果仅仅想看正确步骤,建议直接看第八点的配置步骤再返回查找各步骤的操作。

美洲杯赌球 1 

我们如果需要配置webpack指令的其他参数,只需要在webpack –mode production/development后加上其他参数即可,如:

environment.js代码如下:

CLI(命令行工具)已经转移到了一个单独的包webpack-cli中。
除了webpack自身外,请额外安装webpack-cli来使用CLI。
-> 使用npm安装:npm install webpack-cli -D
->使用yarn安装:yarn add webpack-cli -D

大多数项目都有生产环境和开发环境,一般情况下应该够了,但是有时候还需要sit,uat,本地等环境,这时候假如要通过注释的方式切换环境就相当麻烦了. 如果可以像下面这样切换环境就方便了

我们卸载本地安装的webpack-cli,全局安装webpack-cli:

我默认打包是打包生产环境,当然你也可以输入参数打包其他环境

以后我们只需要在命令行执行npm run dev便相当于执行webpack --mode development,执行npm run build便相当于执行webpack --mode production

你运行 npm run build 得到的就是production

The CLI moved into a separate package:webpack-cli.
Please install 'webpack-cli' in addition to webpack itself to use the CLI.
->when using npm: npm install webpack-cli -D
->when using yarn: yarn add webpack-cli -D

vue.config.js代码如下:

希望本文所述对大家基于webpack的前端程序设计有所帮助。

美洲杯赌球 2 

很不幸,还是提示:

如果对@vue/cli还不熟的话,建议看看这篇文章https://www.jb51.net/article/138055.htm

我们在项目根目录新建一个文件hello.js,并在其中输入代码:

const webpack = require('webpack')
const environment = require('./build/environment')
module.exports = {
 baseUrl: '/wxperp/',
 configureWebpack: {
 plugins: [
 new webpack.DefinePlugin({
 'process.env.STAGE': JSON.stringify(environment.stage),
 'process.env.LOCAL_URL': JSON.stringify(environment.localUrl)
 })
 ]
 }
}

现在如果我们再次执行

(() => {
 const urlMap = {
 local: process.env.LOCAL_URL   'api',
 sit: 'http://xxx.xxx.xxx:xxxx/sit/api',
 uat: 'http://xxx.xxx.xxx:xxxx/uat/api',
 prod: 'http://xxx.xxx.xxx:xxxx/prod/api'
 }
 //sit,uat,prod
 let stage = process.env.STAGE
 //development,production
 const nodeEnv = process.env.NODE_ENV
 //nodeEnv为production并且stage不存在默认为生产环境
 if (nodeEnv === 'production' && !stage) {
 stage = 'prod'
 } else {
 //stage不存在默认为本地开发环境
 stage = stage || 'local'
 }
 console.log('ip:'   urlMap[stage])
})()

配置步骤:

你运行 npm run serve 得到的就是development

这样便能够实现将'./src/index.js'打包成'./dist/main.js'。

然后在根目录创建一个build文件夹,里面创建一个environment.js的文件

意思是,我们需要额外安装webpack-cli,否则便不能在命令行中使用webpack的相关命令。

这个stage就是你输入的变量,比如你输入 npm run serve -sit那么stage的值就为sit

我们再次尝试打包:

美洲杯赌球 3 

意思是将hello.js打包成另一个文件bundle.js。但很不幸,4.1.1版本会提示:

接下来再src目录下面创建一个config.js,记得在main.js中引用这个config.js

npm uninstall webpack-cli
npm install -g webpack-cli

new webpack.DefinePlugin的作用是允许你创建一个在编译时可以配置的全局常量

"dev":"webpack --mode development",
 "build":"webpack --mode production"

美洲杯赌球 4 

function hello(str) {
  alert(str);
}
hello('hello world!');

environment.js代码如下:

我们看到进行了打包并显示了Hash、Version、Time、Build at信息,表明已经可以打包。不过,仍然有错误提示:

总结

当执行该操作后,便在C:Users你的用户名AppDataRoamingnpmnode_modules创建了webpack文件夹,里面存储了刚刚全局安装的webpack模块。

npm run build -sit //打包后使用sit环境

1、创建工程目录;
2、初始化工程目录:npm init。
3、全局安装webpack-cli。
4、全局安装webpack。
5、webpack –mode development/production进行打包,可在package.json中配置dev和build的脚本,便只需运行npm run dev/build,作用相同。
6、在webpack –mode development/production可串联设置其他参数。

您可能感兴趣的文章:

配置警告:
“mode”选项尚未设置。将“mode”选项设为“development”或“production”以启用此环境的默认设置。
multi错误 ./ hello.js bundle.js
未发现模块:错误:无法解析'C:/Users/你的用户名/Desktop/webpack-test'中的bundle.js
@ multi ./hello.js bundle.js

这个localUrl就是你本地的ip,不过很多人应该用不到,我们公司比较特殊,开发的时候,接口请求的地址都是请求的自己本地服务器, 如果不自动获取本地ip,那么每个同事都得在配置文件中保留一份自己得ip地址,很麻烦,所以就自动获取了.

这里-D参数和–save-dev的作用相同,只是一种简写而已。笔者这里安装完成后,显示webpack-cli版本是2.0.10。

npm run serve //默认本地开发环境

七、配置其他参数

npm run build //默认打包后使用生产环境

webpack hello.js bundle.js

再啰嗦下,process.env.NODE_ENV是@vue/cli提供的,貌似有三个值(development,production,test),

我们在合适位置新建一个文件夹webpack-test,用于存放我们的项目。
命令行中定位到webpack-test文件夹下,输入以下命令进行项目的初始化:

npm run serve -uat //本地开发中使用uat环境

这表明webpack4.x是以项目根目录下的'./src'作为入口,但我们的项目中缺乏该路径,因此我们在根目录下创建src文件夹,事实上webpack4.x以'./src/index.js'作为入口,单单创建src文件而没有index.js文件仍然会报错,因此我们

我们输入 npm run serve -sit ,页面打印如下:

未找到入口模块发生错误:错误:无法解析'C:/Users/你的用户名/Desktop/webpack-test'中的'./src'

const os = require('os')
// 获取命令行变量
const configArgv = JSON.parse(process.env.npm_config_argv)
const original = configArgv.original.slice(1)
const stage = original[1] ? original[1].replace(/-/g, '') : ''
// 本地ip地址
let localUrl
try {
 const network = os.networkInterfaces()
 localUrl = network[Object.keys(network)[0]][1].address
} catch (e) {
 localUrl = 'localhost'
}
localUrl = 'http://'   localUrl   '/'

module.exports = {
 stage, localUrl
}
npm install -g webpack

以上所述是小编给大家介绍的基于vue cli 通过命令行传参实现多环境配置,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

我们在项目中本地安装webpack-cli

`npm run build -uat //打包后使用uat环境

然后,我们便可以满怀期待地尝试打包,在命令行输入:

这表明我们本地安装webpack-cli后并没有起作用,在命令行中依然不能使用webpack命令。那么是什么地方出了问题呢?
我们不难想到,

五、设置模式

因此我们不再按webpack 文件a 文件b的方式运行webpack指令,而是直接运行

ERROR in Entry module not found:ERROR:Can't resolve './src' in 'C:/Users/你的用户名/Desktop/webpack-test'

TAG标签:
版权声明:本文由美洲杯赌球发布于计算机教程,转载请注明出处:美洲杯赌球基于vue cli 通过命令行传参实现多环境