Nuxt3入门:样式的注入、定义和使用(第3节)

2024-09-01 01:20

本文主要是介绍Nuxt3入门:样式的注入、定义和使用(第3节),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

你好同学,我是沐爸,欢迎点赞、收藏、评论和关注。

Nuxt 在样式方面非常灵活。可以自定义样式,或引用本地和外部样式表,或使用 CSS 预处理器、CSS 框架、UI 库和 Nuxt 模块来设置应用程序的样式。

一、在组件中注入本地样式表

本地样式表放在 assets/ 目录下,可以使用 ~/assets/ 别名来引用它们。

你可以直接在页面、布局和组件中导入样式表,你可以使用 javascript 导入或 css @import 导入。

pages/index.vue

<script>// 使用静态导入以实现服务器兼容性import "~/assets/css/first.css";// 注意:动态导入不兼容服务器端import("~/assets/css/first.css");
</script><style>@import url("~/assets/css/second.css");
</style>

二、全局注入本地样式表

export default defineNuxtConfig({css: ["~/assets/css/main.css"],
});

三、全局注入本地字体

将本地字体文件放在 assets/ 目录中,

定义字体。assets/css/main.css

@font-face {font-family: "FarAwayGalaxy";src: url("/fonts/FarAwayGalaxy.woff") format("woff");font-weight: normal;font-style: normal;font-display: swap;
}

使用字体。

<style>h1 {font-family: "FarAwayGalaxy", sans-serif;}
</style>

四、分发来自 NPM 的样式表

以 animate.css 为例。

安装

npm install animate.css

局部引入:页面、布局和组件

app.vue

<script>import "animate.css";
</script><style>@import "animate.css";
</style>

全局引入:nuxt.confg.ts

export default defineNuxtConfig({css: ["animate.css"],
});

五、注入外部样式表

1.全局样式

你可以通过在 nuxt.config 文件的 head 部分中添加 link 元素,在应用程序中包含外部样式表。

export default defineNuxtConfig({head: {link: [{rel: "stylesheet",href: "https://cdn.jsdelivr.net/npm/animate.css@4.1.1/animate.min.css",},],},
});

2.局部样式 - 动态添加

useHead({ link: [ { rel: 'stylesheet', href:
'https://cdnjs.cloudflare.com/ajax/libs/animate.css/4.1.1/animate.min.css' } ]
})

六、使用 CSS 预处理器

Nuxt3 支持使用 CSS 预处理器,如 Sass、Less、Stylus 等。

注册本地 scss 样式表

安装

npm install sass

使用

app.vue

<style lang="scss">@use "~/assets/scss/main.scss";h1 {color: red;}
</style>

全局注入本地 scss 文件

export default defineNuxtConfig({css: ["~/assets/scss/main.scss"],
});

全局注入 scss 样式变量

assets/_color.scss

$primary: blue;
$secondary: red;

nuxt.config.ts

export default defineNuxtConfig({vite: {css: {preprocessorOptions: {scss: {additionalData: '@use "~/assets/_colors.scss" as *;',},},},},
});

app.vue

<style lang="scss">h1 {color: $primary;}
</style>

七、单文件组件样式

类和样式绑定

你可以利用 Vue SFC 功能来使用 class 和 style 属性来设置组件的样式。

<script setup lang="ts">const isActive = ref(true);const hasError = ref(false);const classObject = reactive({active: true,"text-danger": false,});
</script><template><divclass="static":class="{ active: isActive, 'text-danger': hasError }"></div><div :class="classObject"></div>
</template>

class 和 style 属性设置组件的样式属于 Vue 的基本功能之一。更多信息请参考 Vue 文档。

动态样式 v-bind

你可以使用 v-bind 函数在你的样式块中引用 JavaScript 变量和表达式。 绑定将是动态的,这意味着如果变量值发生更改,样式将更新。

<script setup lang="ts">const color = ref("red");
</script><template><div class="text">hello</div>
</template><style>.text {color: v-bind(color);}
</style>

作用域样式

scoped 属性允许您单独设置组件的样式。使用此属性声明的样式将仅适用于此组件。

<template><div class="example">hi</div>
</template><style scoped>.example {color: red;}
</style>

预处理器支持

SFC 样式块支持预处理器语法。Vite 内置了对 .scss、.sass、.less、.styl 和 .stylus 文件的支持,无需配置。您只需先安装它们,它们将直接在 SFC 中使用 lang 属性。

<style lang="scss">/* Write scss here */
</style>

CSS 模块

你可以将 CSS 模块与 module 属性一起使用。使用注入的变量访问它:$style

<template><p :class="$style.red">This should be red</p>
</template><style module>.red {color: red;}
</style>

八、利用布局实现多种样式

如果需要完全不同地设置应用程序不同部分的样式,可以使用布局。 为不同的布局使用不同的样式。

<template><div class="default-layout"><h1>Default Layout</h1><slot /></div>
</template><style>
.default-layout {color: red;
}
</style>

好了,分享结束,谢谢点赞,下期再见!

这篇关于Nuxt3入门:样式的注入、定义和使用(第3节)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125545

相关文章

CSS3 布局样式及其应用举例

《CSS3布局样式及其应用举例》CSS3的布局特性为前端开发者提供了无限可能,无论是Flexbox的一维布局还是Grid的二维布局,它们都能够帮助开发者以更清晰、简洁的方式实现复杂的网页布局,本文给... 目录深入探讨 css3 布局样式及其应用引言一、CSS布局的历史与发展1.1 早期布局的局限性1.2

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Python文件操作与IO流的使用方式

《Python文件操作与IO流的使用方式》:本文主要介绍Python文件操作与IO流的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python文件操作基础1. 打开文件2. 关闭文件二、文件读写操作1.www.chinasem.cn 读取文件2. 写

PyQt6中QMainWindow组件的使用详解

《PyQt6中QMainWindow组件的使用详解》QMainWindow是PyQt6中用于构建桌面应用程序的基础组件,本文主要介绍了PyQt6中QMainWindow组件的使用,具有一定的参考价值,... 目录1. QMainWindow 组php件概述2. 使用 QMainWindow3. QMainW

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

java变量内存中存储的使用方式

《java变量内存中存储的使用方式》:本文主要介绍java变量内存中存储的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍2、变量的定义3、 变量的类型4、 变量的作用域5、 内存中的存储方式总结1、介绍在 Java 中,变量是用于存储程序中数据

关于Mybatis和JDBC的使用及区别

《关于Mybatis和JDBC的使用及区别》:本文主要介绍关于Mybatis和JDBC的使用及区别,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、JDBC1.1、流程1.2、优缺点2、MyBATis2.1、执行流程2.2、使用2.3、实现方式1、XML配置文件

macOS Sequoia 15.5 发布: 改进邮件和屏幕使用时间功能

《macOSSequoia15.5发布:改进邮件和屏幕使用时间功能》经过常规Beta测试后,新的macOSSequoia15.5现已公开发布,但重要的新功能将被保留到WWDC和... MACOS Sequoia 15.5 正式发布!本次更新为 Mac 用户带来了一系列功能强化、错误修复和安全性提升,进一步增

Java资源管理和引用体系的使用详解

《Java资源管理和引用体系的使用详解》:本文主要介绍Java资源管理和引用体系的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Java的引用体系1、强引用 (Strong Reference)2、软引用 (Soft Reference)3、弱引用 (W