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

date: 2024/7/29

updated: 2024/7/29

author: cmdragon

excerpt:

本文详细介绍了Nuxt.js中的运行时配置功能,包括定义和使用运行时配置的方法,以及如何通过useRuntimeConfig访问配置。同时,讲解了环境变量与.env文件的使用,特别是在不同环境下的配置管理。

categories:

  • 前端开发

tags:

  • Nuxt.js
  • 运行时配置
  • Vue.js
  • SSR
  • 环境变量
  • .env文件
  • useRuntimeConfig



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

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

一、什么是运行时配置?

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

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

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

export default defineNuxtConfig({
runtimeConfig: {
// 私有密钥,仅在服务器端可用
apiSecret: '123', // 公共密钥,可以在客户端和服务器端访问
public: {
apiBase: process.env.NUXT_PUBLIC_API_BASE || '/api'
}
}
})

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

三、如何使用 useRuntimeConfig

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

<template>
<div>
<h1>API Base URL: {{ config.public.apiBase }}</h1>
</div>
</template> <script>
export default {
setup() {
const config = useRuntimeConfig()
return {
config
}
}
}
</script>

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

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

四、环境变量与 .env 文件

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

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调用、路由链接、静态资源访问等场景中。

如何使用

// 在你的组件中访问baseURL
export default {
setup() {
const config = useRuntimeConfig()
console.log('Base URL:', config.app.baseURL)
}
}

2. app.cdnURL

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

如何使用

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

设置环境变量

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

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

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

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

示例代码

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

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

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

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

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

余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:Nuxt.js必读:轻松掌握运行时配置与 useRuntimeConfig | cmdragon's Blog

往期文章归档:

Nuxt.js必读:轻松掌握运行时配置与 useRuntimeConfig的更多相关文章

  1. Xcode 运行时配置

    有时候,我们的app在测试时需要连接到一个testing服务器,在打包为企业证书的app时又需要连接到另一个ad hoc 服务器,或者我们想企业证书打包的app和debug模式打包的app有不同的AP ...

  2. Laravel 使用 Provider 为程序提供运行时配置服务

    需求: 配置参数存在数据库中,Model 是 aah,需要在每次运行时,程序可以在任何地方采用 config("aah.name") 的方式访问配置信息. 思路: 采用 Provi ...

  3. opcache运行时配置参数详解

    PHP的opcode缓存又出 了新成员(说新不新,也有一段日子了),那就是opcache.新浪微博等都在使用,惠新宸老师强力推荐.本人最近根据官网地址 (http://www.php.net/manu ...

  4. 使用nuxt.js官方脚手架构建项目时ES6编译问题SyntaxError: Unexpected token import

    用nuxt集成koa2做vue后台,官方自带脚手架搭建的koa2仍是ES5语法,在构建koa2时默认的nodemon是没有使用babel编译的, 所以首先需要在启动命令后加上--exec babel- ...

  5. fn project 运行时配置选项

    Env Variables Description Default values DB_URL The database URL to use in URL format. SeeDatabases  ...

  6. ETCD:运行时重新配置

    原文地址:runtime reconfiguration etcd带有增量运行时重新配置的支持.允许我们在集群运行的时候更新集群成员关系. 仅当大多数集群成员都在运行时,才能处理重新配置请求,强烈建议 ...

  7. ETCD:运行时重新配置设计

    原文地址:the runtime configuration design 运行时重新配置是分布式系统中最难,最容易出错的部分,尤其是在基于共识(像etcd)的系统中. 阅读并学习关于etcd的运行时 ...

  8. DevExpres表格控件运行时动态设置表格列

    本文是系列文章,陆续发表于电脑编程技巧与维护杂志. DevExpres产品是全球享有极高声誉的一流控件套包产品!国内典型用户包括:用友.金蝶.神州数码.工信部.中国石化.汉王科技等众多大中型科技型企业 ...

  9. SET - 改变运行时参数

    樊伟胜SYNOPSIS SET [ SESSION | LOCAL ] name { TO | = } { value | 'value' | DEFAULT } SET [ SESSION | LO ...

  10. 浅析容器运行时奥秘——OCI标准

    背景 2013年Docker开源了容器镜像格式和运行时以后,为我们提供了一种更为轻量.灵活的"计算.网络.存储"资源虚拟化和管理的解决方案,在业界迅速火了起来. 2014年更是容器 ...

随机推荐

  1. 调试YOLOv3/YOLOv5过程中遇到的问题汇总

    今日立冬 yolov1 yolo1论文 https://www.bilibili.com/video/BV15w411Z7LG yolo2论文 https://www.bilibili.com/vid ...

  2. 机器学习算法(一):1. numpy从零实现线性回归

    系列文章目录 机器学习算法(一):1. numpy从零实现线性回归 机器学习算法(一):2. 线性回归之多项式回归(特征选取) @ 目录 系列文章目录 前言 一.理论介绍 二.代码实现 1.导入库 2 ...

  3. ETL工具-nifi干货系列 第三讲 nifi web ui 使用教程

    1.nifi 服务启动之后,浏览器输入https://localhost:8443/nifi ,匿名登录或者输入用户名密码进入操作页面,如下图所示: 2.组件工具栏 处理器,鼠标放到图标上提示Proc ...

  4. 小米 红米 MIUI 重新打开(开启)蓝牙耳机电量弹窗

    原本关闭了下拉通知栏,显示耳机电量的窗口.想重新开开启. 解决方法: 1.确保小爱同学开了通知权限. 2.在蓝牙-高级设置里-开启"小米快连" 3.手机是解锁状态(非锁屏),耳机需 ...

  5. 如何生成war包

    pom.xml <packaging>war</packaging> 引入tomcat <dependency> <groupId>org.spring ...

  6. react的类组件的ts写法

    react的类组件的ts写法,声明的变量,props和state的写法 import React, { PureComponent } from 'react'; interface Iprops { ...

  7. java多线程编程:你真的了解线程中断吗?

    java.lang.Thread类有一个 interrupt 方法,该方法直接对线程调用.当被interrupt的线程正在sleep或wait时,会抛出 InterruptedException 异常 ...

  8. WebUI测试-获取html页面表格数据并存到Excel中

    from selenium.webdriver.support import expected_conditions as EC import pandas as pd table=WebDriver ...

  9. MySQL bit类型增加索引后查询结果不正确案例浅析

    昨天同事遇到的一个案例,这里简单描述一下:一个表里面有一个bit类型的字段,同事在优化相关SQL的过程中,给这个表的bit类型的字段新增了一个索引,然后测试验证 时,居然发现SQL语句执行结果跟不加索 ...

  10. 多Github账号指定ssh-key提交代码

    问题 目前github中代码提交只能通过ssh方式. 每个github账号只能添加一个专用的ssh-key. 如果同时有多个Github账号在用的话就必须给每个账号绑定不同的ssh-key. 方法一: ...