网站首页 > 技术文章 正文
在 Vue 里写样式,基本上都 Sass 起步。Sass 变量有很多好处,其中之一就是定义变量,在写类似 danger, warning, info, primary 样式的时候就不用每次都对颜色背景硬编码了,而是直接用先前定义好的 Sass 变量。写 UI 组件的时候,如何全局Sass, 方法大概有三种,下面就简单总结一下。
每个文件引入
假如现在我们已经将变量都定义在 global.scss 文件上了,如果要在某个 .vue 文件里使用变量就要先将其引入。
<template>
...
</template>
<script>
...
</script>
<style lang="scss">
@import ("你的路径/global.scss");
.button {
background: $--primary-bg;
}
</style>
但是这种方法不长久,如果我们每个组件都要引入,那不是每个 .vue 都要 @import 一次?有点太麻烦了。
App.vue
如果你写的是一个网站,那么肯定会用到 App.vue 这个文件。所以你可以在 App 这个组件里 @import。注意:不要在 App 组件里写 scoped ,这样引入的样式都会应用到每个组件上。
<template>
...
</template>
<script>
...
</script>
<style lang="scss">
@import "你的路径/global.scss";
...
</style>
如果App.vue 里有别的代码,那你可以将 App 独立出来,如将 App 包裹你的项目代码,这相当于 HomePage 才是你真正的 App。
App
HomePage
loader引入
sass-resources-loader 可以将你的 .scss 文件作为全局引入,但是这个是要与 webpack 结合的。vue-cli3或者vue-cli4 也是通过修改vue.config.js 来实现。
猜你喜欢
- 2024-09-10 一个基于vite构建的vue3+pinia+ts+element初始化开箱即用的项目
- 2024-09-10 GitHub一篇《Vue 加载远程组件解决方案》,引起业内大佬点评
- 2024-09-10 页面刷新时vuex数据持久化问题的解决方案:第三方插件完美实现
- 2024-09-10 基于vite + Vue3 + element-plus的前后端分离基础项目搭建
- 2024-09-10 Vue导入模块import xxx from '@/xxx'中的@是什么含义?
- 2024-09-10 终于搞懂了!原来 Vue 3 的 generate 是这样生成 render 函数的
- 2024-09-10 Vue3 + TS 中使用 Provide/Inject 需要考虑的三大问题
- 2024-09-10 关于Vue3的setup attribute标识是否是一个值得使用的语法糖?
- 2024-09-10 聊一聊如何在Vue中使用事件总线( Event Bus)进行组件间通信
- 2024-09-10 vite+vue3实现网页版编辑器,带高亮以及代码提
- 02-21走进git时代, 你该怎么玩?_gits
- 02-21GitHub是什么?它可不仅仅是云中的Git版本控制器
- 02-21Git常用操作总结_git基本用法
- 02-21为什么互联网巨头使用Git而放弃SVN?(含核心命令与原理)
- 02-21Git 高级用法,喜欢就拿去用_git基本用法
- 02-21Git常用命令和Git团队使用规范指南
- 02-21总结几个常用的Git命令的使用方法
- 02-21Git工作原理和常用指令_git原理详解
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)