Nuxt 菜鸟入门学习笔记二:配置

news2024/11/25 1:50:40

文章目录

  • Nuxt 配置
    • 环境覆盖
    • 环境变量和私有令牌
  • 应用配置
  • runtimeConfig 与 app.config
  • 外部配置文件
  • Vue 配置支持
    • 配置 Vite
    • 配置 webpack
    • 启用试验性 Vue 功能

Nuxt
Nuxt 官网地址: https://nuxt.com/

默认情况下,Nuxt 的配置涵盖了大多数用例。nuxt.config.ts 文件可以覆盖或扩展默认配置。

Nuxt 配置

nuxt.config.ts文件位于 Nuxt 项目的根目录,可以覆盖或扩展应用程序的行为。

最小配置文件导出defineNuxtConfig函数,该函数包含一个包含您的配置的对象。defineNuxtConfig辅助函数无需导入即可全局使用。

export default defineNuxtConfig({
  // My Nuxt config
});

该文件经常在文档中提及,例如用于添加自定义脚本、注册模块或更改渲染模式。

环境覆盖

您可以在 nuxt.config 中配置完全类型化的环境重载。

// nuxt.config.ts

export default defineNuxtConfig({
  $production: {
    routeRules: {
      "/**": { isr: true },
    },
  },
  $development: {
    //
  },
});

环境变量和私有令牌

runtimeConfig API 将环境变量等值公开(暴露)给应用程序的其他部分。默认情况下,这些键值只在服务器端可用。runtimeConfig.public中的键值在客户端也是可用的。

这些值应在nuxt.config中定义,并可使用环境变量覆盖。

// nuxt.config.ts

export default defineNuxtConfig({
  runtimeConfig: {
    // The private keys which are only available server-side
    // 最外层的key只能使用在服务端
    apiSecret: "123",
    // 在public下的key在服务端和客户端都可以使用
    public: {
      apiBase: "/api",
    },
  },
});

在环境变量.env文件中进行覆盖:

// .env

# 将覆盖nuxt.config中的apiSecret
NUXT_API_SECRET=api_secret_token

这些变量将通过useRuntimeConfig组合式函数暴露给应用程序的其他部分。

// pages/index.vue

<script setup>const runtimeConfig = useRuntimeConfig();</script>

应用配置

app.config.ts文件位于源代码目录(默认情况下位于项目根目录)中,用于公开可在构建时确定的公有变量。与 runtimeConfig 选项相反,这些变量不能通过环境变量覆盖。

一个最小的配置文件导出defineAppConfig函数,该函数包含一个包含配置的对象。defineAppConfig辅助函数无需导入即可全局使用。

// app.config.ts

export default defineAppConfig({
  title: "Hello Nuxt",
  theme: {
    dark: true,
    colors: {
      primary: "#ff0000",
    },
  },
});

这些变量通过使用 useAppConfig 可组合变量暴露给应用程序的其他部分。

// pages/index.vue

<script setup>
  const appConfig = useAppConfig(); console.log({appConfig}); //
  如果此处运行结果为undefined,可重启服务后尝试
</script>

runtimeConfig 与 app.config

如上所述,runtimeConfigapp.config都用于向应用程序的其他部分公开变量。要确定是使用其中一个还是另一个,这里有一些指导原则:

  • runtimeConfig:需要在构建后使用环境变量指定的私有或公用令牌。

  • app.config:在构建时确定的公共令牌、网站配置(如主题变体、标题和任何不敏感的项目配置)。

    特性**runtimeConfig****app.config**
    客户端HydratedBundled
    环境变量YesNo
    ReactiveYesYes
    类型支持部分全部
    每个请求的配置NoYes
    模块热更新NoYes
    非原始 JS 类型NoYes

外部配置文件

Nuxt 使用nuxt.config.ts文件作为配置的唯一信任来源,并跳过读取外部配置文件。在构建项目的过程中,您可能需要配置这些配置。下表强调了常见的配置,以及在适用的情况下,如何使用 Nuxt 配置它们。

配置项原始配置文件Nuxt 中如何配置
Nitronitro.config.tsUse nitro key in nuxt.config
PostCSSpostcss.config.jsUse postcss key in nuxt.config
Vitevite.config.tsUse vite key in nuxt.config
webpackvite.config.tsUse webpack key in nuxt.config

以下是其他常见配置文件的列表:

配置项配置文件如何配置
TypeScripttsconfig.json查看详情
ESLint.eslintrc.js查看详情
Prettier.prettierrc.json查看详情
Stylelint.stylelintrc.json查看详情
TailwindCSStailwind.config.js查看详情
Vitestvitest.config.ts查看详情

Vue 配置支持

配置 Vite

如果需要将选项传递给 @vitejs/plugin-vue 或 @vitejs/plugin-vue-jsx,可以在 nuxt.config 文件中完成。

  • vite.vue 用于 @vitejs/plugin-vue。点此查看可用选项。
  • vite.vueJsx 用于 @vitejs/插件-vue-jsx。点此查看可用选项。
// nuxt.config.ts

export default defineNuxtConfig({
  vite: {
    vue: {
      customElement: true,
    },
    vueJsx: {
      mergeProps: true,
    },
  },
});

配置 webpack

如果您使用 webpack 并需要配置 vue-loader,您可以使用 nuxt.config 文件中的webpack.loaders.vue key 来配置。点击这里查看定义了的可用选项。

// nuxt.config.ts

export default defineNuxtConfig({
  webpack: {
    loaders: {
      vue: {
        hotReload: true,
      },
    },
  },
});

启用试验性 Vue 功能

您可能需要启用 Vue 中的实验特性,如 defineModel 或 propsDestructure。Nuxt 在 nuxt.config.ts 中提供了一种简便的方法,无论您使用哪种构建器:

// nuxt.config.ts

export default defineNuxtConfig({
  vue: {
    defineModel: true,
    propsDestructure: true,
  },
});

本文只是简单介绍了如何对 Nuxt 进行配置,具体配置需要我们结合实际场景和需求进行实践。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/795920.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【雕爷学编程】Arduino动手做(172)---WeMos D1开发板模块4

37款传感器与执行器的提法&#xff0c;在网络上广泛流传&#xff0c;其实Arduino能够兼容的传感器模块肯定是不止这37种的。鉴于本人手头积累了一些传感器和执行器模块&#xff0c;依照实践出真知&#xff08;一定要动手做&#xff09;的理念&#xff0c;以学习和交流为目的&am…

为什么 Raft 原生系统是流数据的未来

虽然Apache Kafka正在逐步引入KRaft以简化其一致性方法&#xff0c;但基于Raft构建的系统对于未来的超大规模工作负载显示出更多的潜力。 ​共识是一致性分布式系统的基础。为了在不可避免的崩溃事件中保证系统的可用性&#xff0c;系统需要一种方式来确保集群中的每个节点保持…

快速跑 nerf instant-ngp 快速调试与配置,跑自己的数据

1.下载Anaconda3 2.打开Anaconda Prompt (Anaconda) 创建虚拟环境 conda create -n nerf-ngp python3.8切换到虚拟环境 conda activate nerf-ngp安装相关依赖包 pip install commentjson imageio numpy opencv-python-headless pybind11 pyquaternion scipy tqdm安装完毕后…

现在设计师都在用哪些工具做UI设计

随着国内企业在用户交互方面的竞争&#xff0c;UI设计的未来是无限的。 如果你仍然或只是在寻找一个合适的UI设计工具&#xff0c;那么这篇文章应该非常适合你。 1.即时设计 即时设计是一款免费的在线 UI 设计工具&#xff0c;无系统限制&#xff0c;浏览器打开即可使用&…

Java面试准备篇:全面了解面试流程与常见问题

文章目录 1.1 Java面试概述1.2 面试流程和注意事项1.3 自我介绍及项目介绍1.4 常见面试问题 在现代职场中&#xff0c;面试是求职过程中至关重要的一环&#xff0c;特别是对于Java开发者而言。为了帮助广大Java开发者更好地应对面试&#xff0c;本文将提供一份全面的Java面试准…

Python中安装pyinstaller并打包为exe可执行程序

环境&#xff1a;vs2022 win10 python3.7.8 工具&#xff1a;pyinstaller 1、安装pyinstaller&#xff0c;cmd --> pip install pyinstaller 2、安装完成后&#xff0c;打开cmd&#xff0c;输入命令&#xff1a;pyinstaller -F xxx.py &#xff0c;xxx为py文件的全路径&am…

超细整理,Python接口自动化测试-关联参数(购物接口实例)

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 什么是参数关联&a…

Hadoop生态体系-2

目录标题 1、MapReduce介绍2、数据仓库3、HIVE4、HQL4.1 hive读写文件机制4.2 Hive数据存储路径 1、MapReduce介绍 思想&#xff1a;分而治之 map:“分”&#xff0c;即把复杂的任务分解为若干个“简单的任务”来处理。可以进行拆分的前提是这些小任务可以并行计算&#xff0c…

3D 渲染技巧-如何创建高质量写实渲染?

掌握创建高质量建筑渲染和任何 3D 渲染的艺术是一项复杂且需要技巧的工作&#xff0c;通常需要多年的经验和实践。实现逼真的结果需要仔细考虑众多因素&#xff0c;并避免可能导致缺乏真实性的假渲染效果的常见错误。 避免常见错误 - 提升渲染游戏的技巧 在追求创建真正逼真的…

数据中心机房机柜配电新模式的探讨与选型

安科瑞 华楠 摘 要&#xff1a;对数据中心机房列头柜配电方式特征和问题进行深入研究&#xff0c;分析机房末端配电安全性及可用性&#xff0c;主要阐述了数据中心机房机柜配电新模式。 关键词&#xff1a;数据中心&#xff1b;机房机柜&#xff1b;配电模式 1 原始配电方案 …

Pycharm中如何设置在新窗口打开项目

settingAppearance&Behavior–System SettingsOpen project in - new window

抑郁症的自我治疗:警惕隐藏在微笑背后的抑郁症

抑郁症是一种常见的心理疾病&#xff0c;它可以隐藏在微笑背后。许多人经常感到沮丧、情绪低落&#xff0c;这时候可能是抑郁症的前兆。然而&#xff0c;自我治疗也是一种非常有效的抑郁症治疗方法。在本文中&#xff0c;我将分享一些关于如何自我治疗抑郁症的方法。 首先&…

递归对比对象函数

在JavaScript中&#xff0c;对象之间的比较通常通过引用进行。当你使用运算符比较两个对象时&#xff0c;它会检查它们是否引用了同一个内存地址&#xff0c;而不是逐个比较对象的属性。 上图可见&#xff0c;obj1和{}是两个不同的对象&#xff0c;尽管它们具有相同的结构&…

运算方法与运算器

一、定点数运算及溢出检测 1. 定点数加法运算 2. 定点数减法运算 3. 数溢出的概念及其判断方法 运算结果超出了某种数据类型的表示范围 &#xff08;1&#xff09;溢出的概念 &#xff08;2&#xff09;溢出的检测方法 溢出只可能发生在同符号数相加 方法1&#xff1a;对操…

Photo Director Ultra 14.7相片大师AI照片编辑中文软件

今天给大家分享的是Photo Director Ultra 14.7相片大师AI照片编辑中文软件。CyberLink PhotoDirector Ultra是一款功能强大的照片编辑软件,它集照片编辑、组织管理和分享于一体。 #资源介绍 Photo Director Ultra 14.7通过智能对象消除、色彩调整、照片滤镜等多种工具实现照片…

【C++】开源:crowcpp微型web框架配置使用

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍crowcpp微型web框架配置使用。 无专精则不能成&#xff0c;无涉猎则不能通。。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#…

二值信号量

Q: 什么是信号量&#xff1f; A: 信号量&#xff08;Semaphore&#xff09;&#xff0c;是在多任务环境下使用的一种机制&#xff0c;是可以用来保证两个或多个关键代码段不被并发调用。 信号量这个名字&#xff0c;我们可以把它拆分来看&#xff0c;“信号”可以起到通知信号…

CSDN原理等级的提升方法

文章目录 原力增长是一种积分型的社交平台&#xff0c;它有多个可以增长用户积分的渠道&#xff0c;也可以升级发付费资源&#xff0c;以下是几个主要的渠道&#xff1a;1.原创文章&#xff1a;2.回答问题&#xff1a;3.发动态&#xff1a;4.浏览文章&#xff1a;5.翻译文章&am…

回归预测 | MATLAB实现SO-CNN-BiLSTM蛇群算法优化卷积双向长短期记忆神经网络多输入单输出回归预测

回归预测 | MATLAB实现SO-CNN-BiLSTM蛇群算法优化卷积双向长短期记忆神经网络多输入单输出回归预测 目录 回归预测 | MATLAB实现SO-CNN-BiLSTM蛇群算法优化卷积双向长短期记忆神经网络多输入单输出回归预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 Matlab实…

8-Linux进程管理

Linux的进程管理 基本介绍显示系统执行的进程ps 指令基本介绍 终止进程kill和killall基本语法 查看进程树 pstree服务 service 管理service介绍service管理指令chkconfig 指令 systemctl 管理指令基本指令systemctl 设置服务的自启动状态示例打开或者关闭指定端口 动态监控进程…