欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于Vue-Cli 打包自動(dòng)生成/抽離相關(guān)配置文件的實(shí)現(xiàn)方法

 更新時(shí)間:2018年12月09日 09:12:38   作者:Strony  
基于Vue-cli 項(xiàng)目產(chǎn)品部署,涉及到的交互的地址等配置信息,每次都要重新打包才能生效,極大的降低了效率。這篇文章主要介紹了基于Vue-Cli 打包自動(dòng)生成/抽離相關(guān)配置文件 ,需要的朋友可以參考下

背景

•基于Vue-cli 項(xiàng)目產(chǎn)品部署,涉及到的交互的地址等配置信息,每次都要重新打包才能生效,極大的降低了效率。我們的目的是讓項(xiàng)目實(shí)施的小伙伴重新快樂起來。網(wǎng)上實(shí)現(xiàn)的方式,都是半自動(dòng)化的,還需要重新修改。

需求點(diǎn)

•配置化:打包后的配置文件可二次修改
•配置自動(dòng)生成:vue-cli 提供了各種環(huán)境的打包,要實(shí)現(xiàn)相關(guān)配置文件的自動(dòng)打包
•研發(fā)人員無痛感:對(duì)于產(chǎn)品研發(fā)人員來說,不需要增加額外的打包成本,基于Vue-cli的開發(fā)習(xí)慣不變。

實(shí)現(xiàn)步驟

一:配置自動(dòng)生成

•安裝generate-asset-webpack-plugin插件。用于配置文件自動(dòng)生成。

npm install --save-dev generate-asset-webpack-plugin

•配置webpack.prod.conf.js文件.新增如下代碼

// 這段代碼在配置文件開頭
var GenerateAssetPlugin = require('generate-asset-webpack-plugin'); //Add:Strony;Date:2018年12月7日
const env = require('../config/' + process.env.env_config + '.env')
// 打包后配置文件:新增 2018年12月7日;Strony
var createServerConfig = function (compilation) {
 //Step1:先復(fù)制原對(duì)象
 var parseEnv = Object.assign({ _hash: compilation.hash}, env)
 //Step2:去除配置文件中的引號(hào)
 Object.keys(parseEnv).forEach(function (key) {
  parseEnv[key] = parseEnv[key].replace(/"/g, "");
 });
 return JSON.stringify(parseEnv, null, 2);
}
// 這段代碼加在plugins:[]中
 new GenerateAssetPlugin({
   filename: utils.assetsPath('../static/serverConfig.json'),
   fn: (compilation, cb) => {
    cb(null, createServerConfig(compilation));
   },
   extraFiles: []
  })

•輸入npm run build:prod 打包命令.vue-cli 默認(rèn)提供了幾個(gè)環(huán)境的打包環(huán)境:早期版本直接:npm run build

結(jié)果如下:


•生成的配置文件樣式如下:

{
 "_hash": "52f44b45b5b600b7f36e",
 "NODE_ENV": "production",
 "ENV_CONFIG": "sit",
 "BASE_API": "http://*****/APIPlateForm/",
 "BASE_ADDR": "http://****/",
 "REPORT_ADDR": "******"
}

二:全局變量從配置文件讀取

1.增加serverConfig.json。目的是開發(fā)人員本地開發(fā)時(shí)候,可以從配置文件讀取。內(nèi)容Copy本地的dev.env.js.住里面的格式為json,去除多余的引號(hào)。


2.在main.js中添加下面的代碼。目的:讀取配置地址掛載在全局對(duì)象

import axios from 'axios'
/* eslint-disable no-new */
// 請(qǐng)求文件內(nèi)容
function getServerConfig() {
 return new Promise((resolve, reject) => {
  axios.get('./static/serverConfig.json').then(result => {
   console.log(result)
   const config = result.data;
   for (const key in config) {
    Vue.prototype[key] = config[key];
   }
   resolve();
  })
 })
}
// 請(qǐng)求文件內(nèi)容及創(chuàng)建實(shí)例
async function main() {
 await getServerConfig();
 console.log('我的地址是' + Vue.prototype.BASE_API)
 axios.defaults.baseURL = Vue.prototype.BASE_API;//axios 的基礎(chǔ)地址從配置文件讀取
 new Vue({
  el: '#app',
  router,
  store,
  template: '<App/>',
  components: { App }
 })
}
// 方法初始執(zhí)行
main();

3.項(xiàng)目執(zhí)行:npm run dev。在瀏覽器的控制臺(tái)下可以查看到相關(guān)的配置信息


4.使用方法:在vue文件中,直接訪問使用各類地址信息。

  handleWatchLib(linurl) {
    window.open(this.BASE_ADDR + linurl);
    return false;
   }

總結(jié)

以上所述是小編給大家介紹的基于Vue-Cli 打包自動(dòng)生成/抽離相關(guān)配置文件的實(shí)現(xiàn)方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue之this.$router.push頁面刷新問題

    vue之this.$router.push頁面刷新問題

    這篇文章主要介紹了vue之this.$router.push頁面刷新問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • 詳解mpvue實(shí)現(xiàn)對(duì)蘋果X安全區(qū)域的適配

    詳解mpvue實(shí)現(xiàn)對(duì)蘋果X安全區(qū)域的適配

    這篇文章主要介紹了詳解mpvue實(shí)現(xiàn)對(duì)蘋果X安全區(qū)域的適配,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • vue 輸入電話號(hào)碼自動(dòng)按3-4-4分割功能的實(shí)現(xiàn)代碼

    vue 輸入電話號(hào)碼自動(dòng)按3-4-4分割功能的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue 輸入電話號(hào)碼自動(dòng)按3-4-4分割功能的實(shí)現(xiàn)代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-04-04
  • Vue是怎么渲染template內(nèi)的標(biāo)簽內(nèi)容的

    Vue是怎么渲染template內(nèi)的標(biāo)簽內(nèi)容的

    這篇文章主要介紹了Vue是怎么渲染template內(nèi)的標(biāo)簽內(nèi)容的,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • 前端vue-cli項(xiàng)目中使用img圖片和background背景圖的幾種方法

    前端vue-cli項(xiàng)目中使用img圖片和background背景圖的幾種方法

    這篇文章主要介紹了前端vue-cli項(xiàng)目中使用img圖片和background背景圖的幾種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 關(guān)于vue的列表圖片選中打鉤操作

    關(guān)于vue的列表圖片選中打鉤操作

    這篇文章主要介紹了關(guān)于vue的列表圖片選中打鉤操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • element中async-validator異步請(qǐng)求驗(yàn)證使用

    element中async-validator異步請(qǐng)求驗(yàn)證使用

    本文主要介紹了element中async-validator異步請(qǐng)求驗(yàn)證使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Vue.js實(shí)現(xiàn)一個(gè)漂亮、靈活、可復(fù)用的提示組件示例

    Vue.js實(shí)現(xiàn)一個(gè)漂亮、靈活、可復(fù)用的提示組件示例

    這篇文章主要介紹了Vue.js實(shí)現(xiàn)一個(gè)漂亮、靈活、可復(fù)用的提示組件示例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • 基于VUE實(shí)現(xiàn)判斷設(shè)備是PC還是移動(dòng)端

    基于VUE實(shí)現(xiàn)判斷設(shè)備是PC還是移動(dòng)端

    這篇文章主要介紹了基于VUE實(shí)現(xiàn)判斷設(shè)備是PC還是移動(dòng)端,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • Vue中$bus的用法及$on、$off的使用說明

    Vue中$bus的用法及$on、$off的使用說明

    這篇文章主要介紹了Vue中$bus的用法及$on、$off的使用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05

最新評(píng)論