当前位置: 首页 > wzjs >正文

flash建网站教程俄语学习网站

flash建网站教程,俄语学习网站,中国城乡住房和城乡建设部网站,宁夏吴忠网站建设当您运行 npm run generate 生成静态页面时,Vite 的代理服务器确实无法使用,因为生成阶段是在 Node.js 环境中执行的构建过程。但别担心,我将为您提供一套完整的解决方案来处理构建阶段的跨域问题。核心解决方案1. 构建阶段:使用服…

当您运行 npm run generate 生成静态页面时,Vite 的代理服务器确实无法使用,因为生成阶段是在 Node.js 环境中执行的构建过程。但别担心,我将为您提供一套完整的解决方案来处理构建阶段的跨域问题。

核心解决方案


1. 构建阶段:使用服务端中转 API(推荐)

在构建阶段通过 Nuxt 的 server 路由中转请求,避开跨域限制:

// server/api/products.ts
export default defineEventHandler(async (event) => {// 从环境变量获取API地址const apiBase = useRuntimeConfig().public.apiBase// 构建阶段直接调用API(无跨域问题)return await $fetch(`${apiBase}/products`, {headers: {'Authorization': `Bearer ${process.env.API_TOKEN}`}}).catch(() => ([])) // 添加错误处理
})

为什么 server/api/products.ts是服务端中转 API?

文件位于 server/api 目录下,这是 Nuxt 3 中定义服务器端 API 的标准位置。
文件名为 products.ts,表示它处理的是与 /api/products 路径相关的请求

在这个处理函数中,它接收来自客户端的请求(在构建阶段,这个请求来自 Nuxt 的构建进程),然后它自己作为客户端去请求另一个后端服务(${apiBase}/products)。
这个后端服务可能是你真正的业务 API,可能运行在另一个域名或端口上(比如 http://localhost:3001 或 https://api.example.com)。

在构建阶段(npm run generate),Nuxt 是在 Node.js 环境中运行的,所以它直接发起 HTTP 请求(使用 $fetch)到后端服务,这不存在浏览器的同源策略限制(跨域问题只存在于浏览器中)。
在开发阶段,我们通过 Vite 的代理配置(在 nuxt.config.ts 中)将客户端对 /api/products 的请求代理到真正的后端服务,同样避免了浏览器的跨域问题。


2. 页面组件中调用中转 API
<!-- pages/products.vue -->
<script setup>
// 构建时调用的中转API(不存在跨域问题)
const { data: products } = await useAsyncData('products',() => $fetch('/api/products')
)
</script>

​当 Nuxt.js 执行 $fetch('/api/products') 时,它会自动匹配并调用 server/api/products.ts 中定义的中转 API 处理程序​​。这是一个 Nuxt.js 的核心约定机制。

详细的路径匹配规则:
​​目录结构映射​​:

  • 所有放在 server/api/ 目录下的 .ts 文件都会自动注册为 API 端点
  • 文件路径直接对应路由路径:

​​具体匹配过程​​:

文件路径

对应的API路由

server/api/products.ts/api/products
server/api/products/index.ts/api/products
server/api/products/[id].ts  /api/products/:id
server/api/categories/featured.ts /api/categories/featured

​​在页面中调用​​:
// 调用以下路径的API:

$fetch('/api/products')server/api/products.ts
$fetch('/api/products/123')server/api/products/[id].ts
$fetch('/api/categories/featured')

server/api/categories/featured.ts

  1. 处理函数约定​​:

    • 每个文件必须导出 default defineEventHandler 作为请求处理函数
    • Nuxt 自动将请求路由到对应的处理程序
// server/api/products.ts 
export default defineEventHandler(async (event) => { // 所有对 /api/products 的请求都会到达这里 
})

3. 配置环境变量
# .env.production
NUXT_PUBLIC_API_BASE=https://production-api.com
API_TOKEN=your_prod_token# .env.development
NUXT_PUBLIC_API_BASE=http://localhost:3000

4,开发环境 Vite 代理配置
// nuxt.config.ts
export default defineNuxtConfig({vite: {server: {proxy: {// 开发环境代理配置'/api/': {target: process.env.NUXT_PUBLIC_API_BASE || 'http://localhost:3000',changeOrigin: true,rewrite: path => path.replace(/^\/api\//, '')}}}},// 通用配置runtimeConfig: {public: {apiBase: process.env.NUXT_PUBLIC_API_BASE}}
})

5.构建阶段工作流程详解
构建流程 (npm run generate)│├─ 1. 加载 nuxt.config.ts│     读取 runtimeConfig.public.apiBase│├─ 2. 扫描 pages/ 目录│     识别出需要使用数据的页面│├─ 3. 执行页面中的 useAsyncData/useFetch│     → 调用 /api/products│        ↓├─ 4. 路由到 server/api/products.ts│     → 使用 $fetch 访问外部 API│        ↓├─ 5. 获取数据 → 渲染页面 → 生成静态HTML│└─ 6. 输出静态文件到 .output/public
6.创建统一的 API 代理层​​:


文章转载自:

http://mgC0DPQz.fmkjx.cn
http://v9kgt71k.fmkjx.cn
http://hqQLsdRO.fmkjx.cn
http://ZTuP2lsp.fmkjx.cn
http://N7v5fhHR.fmkjx.cn
http://EoyoD4S6.fmkjx.cn
http://vELGD3Q1.fmkjx.cn
http://6dFLNNQT.fmkjx.cn
http://6ZVePZrL.fmkjx.cn
http://eSTuBNUh.fmkjx.cn
http://Z8kOPm7h.fmkjx.cn
http://gkathSht.fmkjx.cn
http://GILYLDG1.fmkjx.cn
http://6htU5HwG.fmkjx.cn
http://ovJleisc.fmkjx.cn
http://Aiaat5H9.fmkjx.cn
http://Oqdn3LmY.fmkjx.cn
http://fHbXJIjs.fmkjx.cn
http://mngn6qIz.fmkjx.cn
http://R6zxNjkG.fmkjx.cn
http://tBuFfJEz.fmkjx.cn
http://34JoiulC.fmkjx.cn
http://OLsD9LzH.fmkjx.cn
http://GF0BCJ19.fmkjx.cn
http://sr2TXk4r.fmkjx.cn
http://0gEli1qE.fmkjx.cn
http://1N2ZkQmf.fmkjx.cn
http://wcOGyhB1.fmkjx.cn
http://hyrsHf8j.fmkjx.cn
http://pMfrgXJU.fmkjx.cn
http://www.dtcms.com/wzjs/774606.html

相关文章:

  • 专业网站定制公司企业查询信息平台官网
  • 建设银行 u盾不弹出网站北京 网站建设 知乎
  • 工程管理毕业设计代做网站网站开发项目计划书ppt
  • 做视频网站盈利多少wordpress还原安装
  • 房山建站公司门户网站开发技术
  • 百度网站主要提供的服务源码商城网站源码
  • php网站实例教程百度手机seo
  • 网站推广策略怎么写电商在线官方
  • 钢管网站模板国际服务器
  • 一个域名可以做几个网站吗论坛网站如何建设
  • 合肥响应式网站建设方案软件定制为什么不给源码
  • 哪些网站是.net开发的电子商务网站开发的流程图
  • 网站推广seo教程98建筑网站
  • 吉林省住房建设安厅网站网站搜索功能实现
  • 青海省公路工程建设总公司网站域名申请好怎么做网站
  • 重庆网站备案必须到核验点建立网站最先进的互联网技术有哪些
  • 大型网站建设套餐织梦生成网站地图
  • 免费设计海报的网站网站建设 会议主持稿
  • 河南建设工程信息网招标公告企业网站seo多少钱
  • 网站开发技术 html河北seo网站设计
  • 创新的常州做网站建设摩托车官网全部车型图
  • 做电商网站需要会些什么数据网站怎么做的
  • wap网站制作动态网站建设做网站多少钱
  • 邢台做外贸网站宁波网站建设服务商
  • 网站基本模板wordpress 默认缩略图
  • 网站优化需要哪些工具免费logo素材
  • 网站的结构与布局优化网站建设风险控制
  • 济南网站搭建公司视频门户网站建设方案
  • 山东省城乡建设厅网站东莞常平有哪些好玩的地方
  • 漳州电脑网站建设wordpress恢复分类目录