当前位置: 首页 > news >正文

CSS中的变量应用——:root,Sass变量,JavaScript中使用Sass变量

:root—— 原生CSS 自定义属性(变量)

在 SCSS 文件中定义 CSS 自定义属性。然后通过 JavaScript 读取这些属性。

// variables.scss  
:root {  --login-bg-color: #293146;--left-menu-max-width: 200px;--left-menu-min-width: 64px;--left-menu-bg-color: #001529;--left-menu-bg-light-color: #0f2438;--left-menu-bg-active-color: var(--el-color-primary);
}

使用示例
在 CSS 中,您可以通过 var() 函数来使用这些变量:

.login {background-color: var(--login-bg-color);
}.left-menu {max-width: var(--left-menu-max-width);min-width: var(--left-menu-min-width);background-color: var(--left-menu-bg-color);
}.left-menu-item.active {background-color: var(--left-menu-bg-active-color);
}

在 SCSS 中使用变量

生成具体的类名,然后在 JavaScript 中通过类名来引用样式。

$namespace: 'myNamespace';  
$elNamespace: 'elementNamespace';  .#{$namespace}__header {  color: blue;  
}  .#{$elNamespace}__button {  background-color: green;  
}

在JavaScript中使用SCSS变量

global.module.scss

// 命名空间
$namespace: v;
// el命名空间
$elNamespace: el;// 导出变量
:export {namespace: $namespace;elNamespace: $elNamespace;
}

:export: 这是一个特殊指令,用于将SASS变量导出到JavaScript中。通过这种方式,你可以在JavaScript代码中访问这些变量。

namespace: 这是导出的变量名,其值为 $namespace 的值,即 v。

elNamespace: 这是另一个导出的变量名,其值为 $elNamespace 的值,即 el。

项目中的使用

useDesign.ts

import variables from '@/styles/global.module.scss'export const useDesign = () => {const scssVariables = variables/*** @param scope 类名* @returns 返回空间名-类名*/const getPrefixCls = (scope: string) => {return `${scssVariables.namespace}-${scope}`}return {variables: scssVariables,getPrefixCls}
}

使用useDesign.ts
Backtop.vue

<script lang="ts" setup>
import { ElBacktop } from 'element-plus'
import { useDesign } from '@/hooks/web/useDesign'defineOptions({ name: 'BackTop' })const { getPrefixCls, variables } = useDesign()const prefixCls = getPrefixCls('backtop')
</script><template><ElBacktop:class="`${prefixCls}-backtop`":target="`.${variables.namespace}-layout-content-scrollbar .${variables.elNamespace}-scrollbar__wrap`"/>
</template>
http://www.lryc.cn/news/480014.html

相关文章:

  • WPF+MVVM案例实战与特效(二十八)- 自定义WPF ComboBox样式:打造个性化下拉菜单
  • 速盾:怎么使用cdn加速?
  • C++ 优先算法 —— 三数之和(双指针)
  • YOLOv7-0.1部分代码阅读笔记-yolo.py
  • 【缓存与加速技术实践】Web缓存代理与CDN内容分发网络
  • MySQL的约束和三大范式
  • Unity网络通信(part7.分包和黏包)
  • 练习题 - DRF 3.x Overviewses 框架概述
  • Linux 经典面试八股文
  • Filter和Listener
  • Go 项目中实现类似 Java Shiro 的权限控制中间件?
  • 【Javascript】-一些原生的网页设计案例
  • SpringBoot开发——Spring Boot 3种定时任务方式
  • Flutter鸿蒙next 实现长按录音按钮及动画特效
  • 【计网】实现reactor反应堆模型 --- 框架搭建
  • 力扣中等难度热题——长度为K的子数组的能量值
  • JSON格式
  • O-RAN前传Spilt Option 7-2x
  • 【GeoJSON在线编辑平台】(2)吸附+删除+挖孔+扩展
  • 确定图像的熵和各向异性 Halcon entropy_gray 解析
  • 大数据-214 数据挖掘 机器学习理论 - KMeans Python 实现 算法验证 sklearn n_clusters labels
  • 算法通关(3) -- kmp算法
  • 5G网卡network connection: disconnected
  • 微积分复习笔记 Calculus Volume 1 - 4.9 Newton’s Method
  • Flutter自定义矩形进度条实现详解
  • 如何设置 TORCH_CUDA_ARCH_LIST 环境变量以优化 PyTorch 性能
  • CSS的三个重点
  • 【笔记】前后端互通中前端登录无响应
  • AI引领PPT创作:迈向“免费”时代的新篇章?
  • HTB:Perfection[WriteUP]