多平台统一管理软件接口,如何实现多平台统一管理软件接口
645
2024-02-04
本文主要介绍"vue项目接口域名动态的获取方法",希望能够解决您遇到有关问题,下面我们一起来看这篇 "vue项目接口域名动态的获取方法" 文章。
需求:
接口域名是从外部 .json 文件里获取的。
思路:
在开始加载项目前 进行接口域名获取,然后重置 接口域名的配置项。
实现:
1、config/index.js 文件 进行基础配置
import axios from axios const config = { requestUrl: http://qiniu.eightyin.cn/path.json, //动态域名所在地址 baseUrl: { dev: /api/, pro: http://xxx.com/ // 接口域名,会被动态覆盖 }, requestRemoteIp: () => { // 动态获取 return new Promise((resolve, reject) => { axios.get(config.requestUrl).then(response => { config.baseUrl.pro = response.data.data.path; config.img.domain = config.baseUrl.pro; resolve() }, err => { reject() }); }); } } export default config2、项目下main.js 文件 进行动态获取
import config from @/config/index.js // 读取接口域名 config.requestRemoteIp().finally(res => { /* eslint-disable no-new */ new Vue({ el: #app, router, components: { App }, template: <App/> }) });3、请求数据
const instance = axios.create({ baseURL: process.env.NODE_ENV === development ? config.baseUrl.dev : config.baseUrl.pro })补充知识:webpack + vue 打包生成公共配置文件(域名) 方便动态修改
需求原因
原来的项目中域名是打包到项目里面的,打包后不能动态配置,只能通过不同的指令打包来切换域名,每天都在测试域名和正式域名来回摩擦,后台大佬说你们可以生成一个配置文件这样就不用频繁打包了直接修改配置文件就好,于是就有了这篇文章。
第一步 安装插件
npm install --save-dev generate-asset-webpack-plugin
第二步 新建配置文件
在项目的根目录下新建 serverConfig.json 以后会根据这个文件去生成打包的配置文件
{"ProdUrl":"http://text.com"}
第三步 引入generate-asset-webpack-plugin
在build/webpack.prod.conf.js中添加
const GenerateAssetPlugin = require(generate-asset-webpack-plugin); const serverConfig = require(../serverConfig.json);//引入根目录下的配置文件 const createJson = function() { return JSON.stringify(serverConfig); }; //plugins 中使用 plugins: [ //打包时生成一个配置文件 new GenerateAssetPlugin({ filename: serverConfig.json, fn: (compilation, cb) => { cb(null, createJson()); }, }), ]第四步 使用配置文件中的内容
这里根据不同项目不同需求代码自行变换,我分享一下我的项目里的使用。在main.js 中vue实例初始化之前将baseURL存到本地
axios.get(serverConfig.json).then( e => { let baseURL = e.data.ProdUrl localStorage.setItem("baseURL", baseURL); new Vue({ el: #app, router, store, i18n, render: h => h(App) }) })由于是使用axios获取,是异步方法,根据情况进行处理。、
好了接下来就再也不用为了域名每天build了
打包后的目录
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~