目录

Nuxt3 实现接口域名动态化

为什么要做接口动态?

  • 多个域名指向同一个项目, 比如www.abc.con和abc.com都指向同一个项目, 写死前缀会出现跨域问题
  • 小公司没有运维, Nginx配置不太熟悉
  • 之前项目的接口前缀一直是通过不同的.env文件配置好的. 想实现下动态化

此时可以通过前端项目实现接口域名动态-根据网站域名来处理, 避免接口跨域

怎么实现?

1, 创建环境配置 .env.developmen和.env.production

ini 复制代码
// .env.developmen (本地开启代理使用)
NUXT_PUBLIC_API_BASE = /api
arduino 复制代码
// .env.production
NUXT_PUBLIC_API_BASE = //www.abc.com

2, 在 nuxt.config.ts 中增加配置, 将环境配置信息加入到项目运行配置中

arduino 复制代码
export default defineNuxtConfig({
  runtimeConfig: {
    public: {
      apiBase: process.env.NUXT_PUBLIC_API_BASE,
    }
  },
})

3, 创建plugins文件夹及下面的api-domain.ts

typescript 复制代码
/**
 * 接口域名 根据网站域名一致
 * 客户端获取域名, 接口请求时使用
 */
import { defineNuxtPlugin } from '#app'

export default defineNuxtPlugin((nuxtApp: any) => {
  // 客户端获取域名
	if (process.client) {
    // 获取项目运行时的配置
      const config = useRuntimeConfig()
    // 获取配置的接口前缀
      const apiBase = config.public.apiBase
    let currentDomain = ''
    // 非本地运行, 协议和域名拼接下
		if (apiBase !== '/api') {
			currentDomain = window.location.protocol + '//' + window.location.host
		} else {
      // 本地运行
      currentDomain = apiBase
    }
    // 注入到项目中
    nuxtApp.provide('apiDomain', currentDomain)
	}
})

4, 组件中使用

xml 复制代码
<script setup lang="ts">
import { useNuxtApp } from '#app';
const nuxtApp = useNuxtApp();
const apiDomain = nuxtApp.$apiDomain;


const getList = async () => {
	try {
		const response = await $fetch(
			`${apiDomain}/getList/abc/111`,
			{
				method: 'POST',
			}
		)
    console.log(response)
		
	} catch (error) {
		console.log(error)
	}
}

onMounted(() => {
	getList()
})
</script>

<template>
</template>

<style scoped>
</style>
本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
心系几秒前
vue项目引入marvinJS
前端·vue.js
李剑一1 分钟前
兄弟们,2025年了!求求你优化一下图片加载吧
前端·vue.js
20263 分钟前
7.抽奖功能lucky-canvas总结
前端
jserTang3 分钟前
前端构建工具漫谈:Webpack、Vite、Turbopack 与 Rspack 的终极对决
前端·webpack·vite
飞飞鱼在摸鱼3 分钟前
document.getElementById("chart") 和 this.$refs.chart的区别
前端
海底火旺4 分钟前
【灵魂拷问】你的JS类型检测真的正确吗?Object.prototype.toString.call才是永远的神!
前端·javascript·面试
前端太佬5 分钟前
Vue3异步数据加载的陷阱与最佳实践:从内存泄漏到优雅实现
前端·javascript·vue.js
小old弟6 分钟前
📊📈数据可视化大屏 —— 基于 Vue 3 和 Echarts 5📊📈
前端
前端太佬8 分钟前
v-show 的隐藏魔法:为什么它比 v-if 更“懒”?
前端·javascript·vue.js
妖刀丿飞8 分钟前
文件预览(pdf word excel ppt等)
前端