Nuxt.js必读:轻松掌握运行时配置与 useRuntimeConfig

avatar
cmdragon 渡劫
image image

扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

Nuxt.js 是一个基于 Vue.js 的框架,它极大地简化了服务端渲染(SSR)和静态站点生成的开发过程。在 Nuxt.js 中,运行时配置是一个强大的功能,允许开发者根据不同的环境(如开发、生产等)动态地调整配置。

一、什么是运行时配置?

运行时配置是 Nuxt.js 中的一个特性,它允许你在不同的环境下使用不同的配置。例如,你可能需要在一个环境中使用一个 API 基础 URL,而在另一个环境中使用另一个 URL。运行时配置可以让你轻松实现这一点。

二、如何定义运行时配置?

在 Nuxt.js 中,你可以在 nuxt.config.ts 文件中定义运行时配置。以下是一个简单的例子:

1
2
3
4
5
6
7
8
9
10
11
12
export default defineNuxtConfig({
runtimeConfig: {
// 私有密钥,仅在服务器端可用
apiSecret: '123',

// 公共密钥,可以在客户端和服务器端访问
public: {
apiBase: process.env.NUXT_PUBLIC_API_BASE || '/api'
}
}
})

在这个例子中,apiSecret 是一个私有密钥,仅在服务器端可用。apiBase 是一个公共密钥,可以在客户端和服务器端访问。

三、如何使用 useRuntimeConfig

useRuntimeConfig 是一个组合函数,用于在组件或 API 接口中访问运行时配置。以下是如何在组件中使用它的示例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<template>
<div>
<h1>API Base URL: {{ config.public.apiBase }}</h1>
</div>
</template>

<script>
export default {
setup() {
const config = useRuntimeConfig()
return {
config
}
}
}
</script>

在服务器端 API 中,你可以这样使用 useRuntimeConfig

1
2
3
4
export default defineEventHandler((event) => {
const config = useRuntimeConfig(event)
// 使用配置
})

四、环境变量与 .env 文件

你可以在 .env 文件中设置环境变量,以便在开发和构建过程中访问它们。例如:

1
2
3
NUXT_PUBLIC_API_BASE = "https://api.localhost:5555"
NUXT_API_SECRET = "123"

这些变量可以通过 process.env 在 Nuxt 应用中访问。

生产运行时中,你应该使用平台的环境变量配置,而不是使用 .env 文件。在构建完成后,当你运行服务器时,.env 文件将不会被读取。具体如何设置环境变量取决于你的环境。

五、app 命名空间

在Nuxt.js中,app命名空间是用于存储一些特定的运行时配置的,这些配置通常与应用的全局行为和设置相关。在app命名空间中,有两个重要的键:baseURL和cdnURL。

1. app.baseURL

作用app.baseURL 是一个用于存储应用的根URL的键。默认情况下,这个值被设置为'/'。这个键主要用于在应用中统一处理URL的前缀,例如在API调用、路由链接、静态资源访问等场景中。

如何使用

1
2
3
4
5
6
7
8
// 在你的组件中访问baseURL
export default {
setup() {
const config = useRuntimeConfig()
console.log('Base URL:', config.app.baseURL)
}
}

2. app.cdnURL

作用app.cdnURL 是一个用于存储CDN(内容分发网络)URL的键。这个键主要用于在生产环境中,当应用使用CDN来加速静态资源的加载时,提供一个自定义的CDN URL。在开发环境中,这个值通常被设置为空字符串或者默认值。

如何使用

1
2
3
4
5
6
7
// 在你的API服务中访问cdnURL
export default defineEventHandler((event) => {
const config = useRuntimeConfig()
const cdnURL = config.app.cdnURL
console.log('CDN URL:', cdnURL)
})

设置环境变量

为了在运行时自定义这些值,你可以通过设置环境变量来实现。例如,为了改变app.baseURL,你可以在.env文件中添加:

1
NUXT_APP_BASE_URL=https://your-custom-base-url.com

对于app.cdnURL,你可以在.env文件中添加:

1
NUXT_APP_CDN_URL=https://your-custom-cdn-url.com

示例代码

假设你有一个plugins/my-plugin.ts文件,你想要在其中使用app.baseURL

1
2
3
4
5
6
export default defineNuxtPlugin((NuxtApp) => {
const config = useRuntimeConfig()
const baseURL = config.app.baseURL
console.log('Using base URL:', baseURL)
})

对于server/api/foo.ts中的app.cdnURL

1
2
3
4
5
6
export default defineEventHandler((event) => {
const config = useRuntimeConfig()
const cdnURL = config.app.cdnURL
console.log('Using CDN URL:', cdnURL)
})

通过这种方式,你可以确保在不同的环境(如开发、测试、生产)中,应用能够使用不同的配置,从而提高应用的灵活性和可维护性。

往期文章归档: