ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

vue打包详情

2019-09-23 12:03:24  阅读:321  来源: 互联网

标签:vue szonline 打包 详情 env net amaz market htmlhttp


说明

本文代码中的配置基于vue-cli2

需求

在实际开发中我们可能有测试环境一套请求API 和 正式环境一套API,尤其是两个环境的域名不同时,就需要我们分环境打不同配置的包

了解 webpack.DefinePlugin 插件

DefinePlugin 此插件可以在打包时定义环境变量,在开发时我们也能在代码中获取定义的环境变量。

用法:

单独配置

plugins: [
    new webpack.DefinePlugin({
      'process.env.mode': '"development"'
    })
    ...
]

写成对象

plugins: [
    new webpack.DefinePlugin({
      'process.env': {
        NODE_ENV: '"development"',
        EVN_CONFIG: '"dev"',
        API_ROOT: '"dev API_ROOT"'
      }
    })
    ...
]

写成配置文件

plugins: [
    new webpack.DefinePlugin({
      'process.env': require('../config/dev.env')
    })
    ...
]
// /config/dev.env.js
'use strict'
const merge = require('webpack-merge')
const prodEnv = require('./prod.env')

module.exports = merge(prodEnv, {
  NODE_ENV: '"development"',
  EVN_CONFIG: '"dev"',
  API_ROOT: '"dev API_ROOT"'
})

在vue-cli2 中/build/webpack.dev.conf.js 文件引用了 /config/dev.env.js文件的配置作为环境变量,因此我们执行npm run dev时(执行/build/webpack.dev.conf.js)就可以在我们开发代码中获得环境变量(console.log(process.env)试一试)

然后我们观察/build/webpack.prod.conf.js(npm run build时执行)

//  /build/webpack.prod.conf.js

const env = require('../config/prod.env')
...

new webpack.DefinePlugin({
  'process.env': env
}),

可见打包时使用的是/build/webpack.prod.conf.js文件配置作为环境变量

安装 cross-env

npm install --save-dev cross-env

cross-env 统一了不同操作系统设置环境变量的方式.
用法:

"scripts": {
    "build": "node build/build.js",
    "build:test": "cross-env NODE_ENV=production env_config=test node build/build.js", //设置了环境变量 NODE_ENV 和 env_config
    "build:prod": "cross-env NODE_ENV=production env_config=prod node build/build.js", //设置了环境变量 NODE_ENV 和 env_config
  }

开始配置

由上面分析,我们得到,要分环境打包,我们针对不同的环境去配置不同的环境变量就可以了。

我们先修改scripts脚本

// package.json
"scripts": {
  "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
  "start": "npm run dev",
  "build": "node build/build.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"
},

我们设置了两个环境变量 NODE_ENV 和 env_config然后执行正常的打包。这里的环境变量设置是方便我们在webpack配置文件中使用

新建环境变量文件

新建 在/config目录下新建test.env.js文件存放test的环境变量

//  /config/test.env.js
'use strict'
module.exports = {
    NODE_ENV: '"testing"',
    EVN_CONFIG:'"test"',
    API_ROOT:'"/test/apis/v1"'
}

修改 webpack.prod.config.js

我门注释掉

//const env = require('../config/prod.env')

修改成

//const env = require('../config/prod.env')
const env_config = process.env.env_config || ''; //执行不同的打包脚本对应不同的env_config值
switch (env_config){
  case 'test': 
        var env= require('../config/test.env');
        break;
  case 'prod': 
        var env= require('../config/prod.env');
        break;
  default:
      var env= require('../config/prod.env');
}
...

在代码中使用

// Home.vue

axios.get(process.env.API_ROOT) ...

在不同环境中使用CDN

webpack 提供一个非常有用的配置,该配置能帮助你为项目中的所有资源指定一个基础路径。它被称为公共路径(publicPath)

我们修改webpack中的 publicPath 来让资源引用地址改为cdn
观察vue-cli我门发现publicPath写在了 /config/index.js文件的build对象中,所以我们修改如下

...
const testCDN = 'https://testcdn.com';
const prodCDN = 'https://prodcdn.com';
build: {
  assetsPublicPath: process.env.env_config=='test'?testCDN:prodCDN
}

也可以将cdn地址统一写在上文中的环境配置文件中

var prodEnv = require('./prod.env');
var testEnv = require('./test.env');
...
build: {
 assetsPublicPath: process.env.env_config=='test'?testEnv.FILE_CDN:prodEnv.FILE_CDN,
}

总结

整体思路就是建不同的打包脚本,然后根据不同的打包脚本,应用相应的环境变量配置文件

http://market.szonline.net/amaz/11583.html
http://market.szonline.net/amaz/11582.html
http://market.szonline.net/amaz/11581.html
http://market.szonline.net/amaz/11579.html
http://market.szonline.net/amaz/11577.html
http://market.szonline.net/amaz/11575.html
http://market.szonline.net/amaz/11573.html
http://market.szonline.net/amaz/11571.html
http://market.szonline.net/amaz/11569.html
http://market.szonline.net/amaz/11566.html
http://market.szonline.net/amaz/11564.html
http://market.szonline.net/amaz/11562.html
http://market.szonline.net/amaz/11560.html
http://market.szonline.net/amaz/11558.html
http://market.szonline.net/amaz/11555.html
http://market.szonline.net/amaz/11553.html
http://market.szonline.net/amaz/11551.html
http://market.szonline.net/amaz/11549.html
http://market.szonline.net/amaz/11547.html
http://market.szonline.net/amaz/11545.html
http://market.szonline.net/amaz/11544.html
http://market.szonline.net/amaz/11543.html
http://market.szonline.net/amaz/11542.html
http://market.szonline.net/amaz/11539.html
http://market.szonline.net/amaz/11537.html
http://market.szonline.net/amaz/11535.html
http://market.szonline.net/amaz/11533.html
http://market.szonline.net/amaz/11530.html
http://market.szonline.net/amaz/11510.html
http://market.szonline.net/amaz/11509.html
http://market.szonline.net/amaz/11508.html
http://market.szonline.net/amaz/11506.html
http://market.szonline.net/amaz/11505.html
http://market.szonline.net/amaz/11504.html
http://market.szonline.net/amaz/11503.html
http://market.szonline.net/amaz/11501.html
http://market.szonline.net/amaz/11500.html
http://market.szonline.net/amaz/11499.html
http://market.szonline.net/amaz/11497.html
http://market.szonline.net/amaz/11496.html
http://market.szonline.net/amaz/11495.html
http://market.szonline.net/amaz/11493.html
http://market.szonline.net/amaz/11492.html
http://market.szonline.net/amaz/11491.html
http://market.szonline.net/amaz/11490.html
http://market.szonline.net/amaz/11489.html
http://market.szonline.net/amaz/11488.html
http://market.szonline.net/amaz/11486.html
http://market.szonline.net/amaz/11485.html
http://market.szonline.net/amaz/11484.html
http://market.szonline.net/amaz/11482.html
http://www.wu0553.com/news/20190923/28070.html
http://www.wu0553.com/news/28069.html
http://www.wu0553.com/news/20190923/28068.html
http://www.wu0553.com/news/28067.html
http://www.wu0553.com/news/28066.html
http://www.wu0553.com/news/28065.html
http://www.wu0553.com/news/28064.html
http://www.wu0553.com/news/28063.html
http://www.wu0553.com/news/28062.html
http://www.wu0553.com/news/28061.html
http://www.wu0553.com/news/28060.html
http://www.wu0553.com/news/28059.html
http://www.wu0553.com/news/28058.html
http://www.wu0553.com/news/28057.html
http://www.wu0553.com/news/28056.html
http://www.wu0553.com/news/20190923/28055.html
http://www.wu0553.com/news/28054.html
http://www.wu0553.com/news/20190923/28052.html
http://www.wu0553.com/news/28051.html
http://www.wu0553.com/news/28050.html
http://www.dfeern.cn/
http://www.wu0553.com/news/28049.html
http://www.wu0553.com/news/28047.html
http://www.wu0553.com/news/28046.html
http://www.wu0553.com/news/28045.html
http://www.wu0553.com/news/28044.html
http://www.wu0553.com/news/28043.html
http://www.wu0553.com/news/28042.html
http://www.wu0553.com/news/28041.html
http://www.wu0553.com/news/28040.html
http://www.wu0553.com/news/28039.html

标签:vue,szonline,打包,详情,env,net,amaz,market,htmlhttp
来源: https://www.cnblogs.com/zjw2004112/p/11571561.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有