Nuxt3 实战 (四):安装 Nuxt UI 和配置 Typescript 类型检查

前言

对于 UI 组件库的选择,我考虑过:Ant Design VueElement-Plus,但感觉这两款组件库太偏向业务风格了,现在项目的搭建最好能偏年轻化一点,最后还是选择了:Nuxt UI,主要是 Nuxt UINuxt 官方推荐的,而且完美兼容 Nuxt,并且是用 TypeScript 编写的,并为所有组件和可组合函数提供类型。

安装 Nuxt UI

  1. 执行安装命令
powershell 复制代码
pnpm add @nuxt/ui
  1. 添加到 nuxt.config 模块中
ts 复制代码
export default defineNuxtConfig({
  modules: ['@nuxt/ui']
})
  1. 需要注意的是,这里 Nuxt UI 会自动安装以下这些模块:

如果以前安装过它们,则应该将它们从模块和依赖项中删除。

  1. 现在,我们可以在 Nuxt 应用中使用所有组件和可组合函数✨,我们在 app.vue 中加入代码:
vue 复制代码
<template>
  <div class="w-screen h-screen flex justify-around items-center">
    <UButton>Button</UButton>
    <UBreadcrumb :links="links" />
    <Icon
      name="uil:github"
      size="48"
    />
  </div>
</template>
<script setup lang="ts">
const links = [
  {
    label: 'Home',
    icon: 'i-heroicons-home'
  },
  {
    label: 'Navigation',
    icon: 'i-heroicons-square-3-stack-3d'
  },
  {
    label: 'Breadcrumb',
    icon: 'i-heroicons-link'
  }
]
</script>

可以看到 Nuxt UI 的组件和 tailwindcss 的类名都生效了:

如果你遇到 icon 类似的错误,你应该还需要安装 @iconify-json/heroicons 这个库

powershell 复制代码
pnpm add @iconify-json/heroicons

配置 TypeScript

  1. 安装依赖
powershell 复制代码
pnpm add -D vue-tsc@^1 typescript
  1. 添加到 nuxt.config 配置中
ts 复制代码
export default defineNuxtConfig({
  // 构建时启动类型检查
  typescript: {
    typeCheck: true
  }
})

总结

到这里,我们的准备工作就完成了,可以在页面组件中使用 Nuxt UI 的组件,后续就可以着手开发页面 Layout 布局。

相关推荐
书中枫叶13 小时前
个人主页网站SEO | 个人博客基于Nuxt
typescript·node.js·nuxt.js
A_nanda1 天前
根据AI提示排查vue前端项目
前端·javascript·vue.js
发现一只大呆瓜1 天前
深入浅出 AST:解密 Vite、Babel编译的底层“黑盒”
前端·面试·vite
发现一只大呆瓜1 天前
前端模块化:CommonJS、AMD、ES Module三大规范全解析
前端·面试·vite
墨鱼笔记1 天前
前端必看:Vite.config.js 最全配置指南 + 实战案例
前端·vite
前端Hardy1 天前
别再手动写 loading 了!封装一个自动防重提交的 Hook
前端·javascript·vue.js
前端Hardy1 天前
前端如何实现“无感刷新”Token?90% 的人都做错了
前端·javascript·vue.js
SuperEugene1 天前
Vue Router 实战规范:path/name/meta 配置 + 动态 / 嵌套路由,统一团队标准|状态管理与路由规范篇
开发语言·前端·javascript·vue.js·前端框架
小彭努力中1 天前
194.Vue3 + OpenLayers 实战:动态位置 + 高度 + 角度,模拟卫星地面覆盖范围
前端·css·vue.js·openlayers·animate
前端Hardy1 天前
纯 HTML/CSS/JS 实现的高颜值登录页,还会眨眼睛!少女心爆棚!
前端·javascript·vue.js