如何在CSS中写变量?一文带你了解前端样式利器

这篇具有很好参考价值的文章主要介绍了如何在CSS中写变量?一文带你了解前端样式利器。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

引言

概念

语法

基本用法

使用场景

全局变量

局部变量

​编辑

媒体查询变量

动态定义

继承变量

自变量

与其他方案的区别

使用方式上

作用域的区别

编译产物

功能及拓展

总结

写在最后


引言

前端的变量写法大致可以分为三大类,分别是CSS-in-JS,CSS预处理器,和CSS原生变量。作为前端开发人员,我们应该了解并善用它们,以便实现更加灵活、可维护的样式。本篇文章将与大家分享一下原生CSS的变量写法

概念

CSS变量也叫自定义属性,在它出现之前,CSS中使用的值通常是硬编码的(静态编写),这导致了样式代码的重复和冗余,在管理和维护大型项目时存在一些困扰和隐患

为了解决这个问题,CSS变量被引入到CSS规范中,使开发者能够声明并重复使用可自定义的样式属性。通过定义和使用变量,我们可以对样式集中管理,减少代码的冗余,提高维护性

语法

在CSS中,使用"--"前缀定义一个变量,例如:--variable。可以在:root伪类中定义变量实现全局作用域,也可以在特定选择器中定义变量以限定作用域。

定义完成后使用var()函数调用变量,并将变量名作为参数传递,例如:var(--variable)。在需要应用变量的地方,使用var(--variable)替代具体的数值或属性值。

基本用法

下面是一个全局变量定义以及使用示例

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title></title>
    <style>
      :root {
        --primary-color: lightblue;
        --primary-font: 20px;
      }
      .theme1 {
        width: 100px;
        height: 100px;
        background: var(--primary-color);
        font-size: var(--primary-font);
      }
    </style>
  </head>
  <body>
    <div class="theme1"></div>
  </body>
</html>

使用场景

全局变量

使用:root选择器可以选中根节点,结合CSS变量可以将变量定义在全局,它有最高优先级,所有元素都可以访问这些变量。正如上面的示例

:root {
  --primary-color: lightblue;
}
.theme1 {
  background: var(--primary-color);
}

局部变量

局部变量(又叫块级变量)的使用范围就比较广了,几乎所有选择器都可以声明变量。下面举几个例子

在类选择器中定义变量,在子标签中使用

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title></title>
    <style>
      .theme1 {
        --primary-color: lightblue;
      }
      .theme1 > span {
        color: var(--primary-color);
      }
    </style>
  </head>
  <body>
    <div class="theme1">
      <span>hello</span>
    </div>
  </body>
</html>

给html设置主题属性,在其他标签中使用。这里我借助JS实现了一个简单的主题切换功能

<!DOCTYPE html>
<html theme="theme1">
  <head>
    <meta charset="UTF-8" />
    <title></title>
    <style>
      [theme="theme1"] {
        --primary-color: lightblue;
        --primary-font-size: 20px;
      }
      [theme="theme2"] {
        --primary-color: lightcoral;
        --primary-font-size: 30px;
      }
      .theme > span {
        color: var(--primary-color);
        font-size: var(--primary-font-size);
      }
    </style>
  </head>
  <body>
    <button onclick="changeTheme()">切换主题</button>
    <div class="theme">
      <span>hello</span>
    </div>
    <script>
      const html = document.querySelector("html");
      function changeTheme() {
        if (html.getAttribute("theme") === "theme1")
          return html.setAttribute("theme", "theme2");
        html.setAttribute("theme", "theme1");
      }
    </script>
  </body>
</html>

效果如下

css 使用变量,CSS,面试文档,前端,css3,css,原力计划

媒体查询变量

在媒体查询的条件下,我们也可以通过声明CSS变量来达到样式动态更新的效果

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title></title>
    <style>
      @media (min-width: 300px) {
        :root {
          --primary-color: lightblue;
          --primary-font-size: 20px;
        }
      }
      @media (min-width: 600px) {
        :root {
          --primary-color: lightcoral;
          --primary-font-size: 30px;
        }
      }
      .theme > span {
        color: var(--primary-color);
        font-size: var(--primary-font-size);
      }
    </style>
  </head>
  <body>
    <div class="theme">
      <span>hello</span>
    </div>
  </body>
</html>

运行上述代码后效果是这样的

css 使用变量,CSS,面试文档,前端,css3,css,原力计划

动态定义

此外我们可以通过element.setProperty的方式对变量值进行动态修改,称为动态定义,操作如下

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title></title>
    <style>
      :root {
        --primary-color: lightblue;
        --primary-font-size: 20px;
      }
      .theme > span {
        color: var(--primary-color);
        font-size: var(--primary-font-size);
      }
    </style>
  </head>
  <body>
    <button onclick="changeTheme()">切换主题</button>
    <div class="theme">
      <span>hello</span>
    </div>
    <script>
      const dom = document.documentElement;
      const { style } = dom;
      const colorKey = "--primary-color";
      function changeTheme() {
        const primaryColor = getComputedStyle(dom).getPropertyValue(colorKey);
        // 格式化后样式有空格
        if (primaryColor.includes("lightblue"))
          style.setProperty(colorKey, "lightcoral");
        else style.setProperty(colorKey, "lightblue");
      }
    </script>
  </body>
</html>

其中getComputedStyle的作用是动态获取当前标签的样式对象, getPropertyValue可以获取标签的自定义属性,接着使用setProperty来设置自定义属性

 css 使用变量,CSS,面试文档,前端,css3,css,原力计划

继承变量

上面提到的:root根元素声明变量,在任意子元素使用实际上就是继承,父标签定义的变量在后代节点都可以访问

自变量

最后是自变量,在同一个选择器中定义的标签可以在自身中访问

与其他方案的区别

了解了上述用法,那么CSS变量与预处理器以及CSS-in-JS有什么区别呢?

使用方式上

CSS变量属于原生语法可以直接使用;预处理器需要对应的编译器;Css in Js是基于JS实现的将CSS嵌入到JS开发(一般在虚拟Dom中比较常用),同样需要对应依赖。

作用域的区别

CSS变量定义于任何选择器中,以父级为基本单位,后代与其产生继承关系;CSS in JS一般是以框架组件为单位,例如CSS Modules,styled-components;而less,sass等处理器使用的是组件或文件级别的作用域。

编译产物

CSS变量是实时运算的;CSS in JS是编译成CSS后嵌入HTML;预处理器是编译成CSS直接使用。

功能及拓展

CSS变量可以定义简单的变量拓展,或者配合CSS函数(calc,min,clamp等)进行运算;CSS in JS则可以使用完整的JavaScript功能;预处理器除了有变量功能,还可以使用复杂功能,如导入,混合,嵌套等

总结

CSS变量适用于定义可重用的样式,无需使用其他依赖,方便快捷,但是功能少;

CSS in JS适用于组件化样式管理,拥有JS语法支持,需要安装依赖,功能比较强大;

CSS预处理器是用于对CSS功能的拓展,同样需要加载依赖,功能也比较强大

它们三者可以相辅相成,配合使用

写在最后

本文主要带大家了解了一下CSS变量的概念及使用场景,并拓展了其与CSS-in-JS及CSS预处理器的区别,CSS变量适用于定义可重用的样式,可以应对简单的场景。

以上就是文章全部内容了,希望你阅读完有所收获,如果觉得文章不错的话,还望支持一下作者,感谢!文章来源地址https://www.toymoban.com/news/detail-737612.html

到了这里,关于如何在CSS中写变量?一文带你了解前端样式利器的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • [网络安全/前端XSS防护]一文带你了解HTML的特殊字符转义及编码

    在 HTML 中,有一些特殊字符不可直接使用,需要使用转义字符或实体编码来表示。这是为了避免这些字符与 HTML 标签和语法产生冲突。同时,也是为了防范前端XSS。 例如,有些特殊字符(如 和 )作为HTML标签的一部分,要是没有被特殊处理可能被恶意XSS。 HTML的特殊字符转义

    2024年02月06日
    浏览(57)
  • 【网络安全/前端XSS防护】一文带你了解HTML的特殊字符转义及编码

    在 HTML 中,有一些特殊字符不可直接使用,需要使用转义字符或实体编码来表示。这是为了避免这些字符与 HTML 标签和语法产生冲突。同时,也是为了防范前端XSS。 例如,有些特殊字符(如 和 )作为HTML标签的一部分,要是没有被特殊处理可能被恶意XSS。 HTML的特殊字符转义

    2024年02月04日
    浏览(45)
  • 一文带你了解IP被封,如何进行解封

    当你的IP地址被封锁时,可能会导致无法正常访问特定网站或服务。本文将为你提供一些有用的步骤和建议,帮助你解封被封锁的IP地址,恢复正常的网络访问。 第一步:确认IP被封的原因 1.检查错误信息:当你尝试访问被封锁的网站或服务时,注意是否出现特定的错误信息。

    2024年02月07日
    浏览(55)
  • 【MySQL】一文带你了解如何使用MySQL

    🎬 博客主页:博主链接 🎥 本文由 M malloc 原创,首发于 CSDN🙉 🎄 学习专栏推荐:LeetCode刷题集! 🏅 欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! 📆 未来很长,值得我们全力奔赴更美好的生活✨ ------------------❤️分割线❤️------------------------- —————————

    2024年02月09日
    浏览(72)
  • 一文带你了解如何在Java中操作Redis

    为了巩固所学的知识,作者尝试着开始发布一些学习笔记类的博客,方便日后回顾。当然,如果能帮到一些萌新进行新技术的学习那也是极好的。作者菜菜一枚,文章中如果有记录错误,欢迎读者朋友们批评指正。 (博客的参考源码可以在我主页的资源里找到,如果在学习的

    2024年02月16日
    浏览(42)
  • 一文带你快速了解如何在Linux上部署项目

    为了巩固所学的知识,作者尝试着开始发布一些学习笔记类的博客,方便日后回顾。当然,如果能帮到一些萌新进行新技术的学习那也是极好的。作者菜菜一枚,文章中如果有记录错误,欢迎读者朋友们批评指正。 (博客的参考源码可以在我主页的资源里找到,如果在学习的

    2024年02月15日
    浏览(45)
  • MAVEN利器:一文带你了解IDEA中如何使用Maven

    强大的构建工具——Maven。作为Java生态系统中的重要组成部分,Maven为开发人员提供了一种简单而高效的方式来构建、管理和发布Java项目。无论是小型项目还是大型企业级应用,Maven都能帮助开发人员轻松处理依赖管理、编译、测试和部署等任务。 在上一篇文章中,我们学习

    2024年02月11日
    浏览(48)
  • 一文带你了解MySQL之InnoDB统计数据是如何收集的

    前言 我们前边唠叨查询成本的时候经常用到一些统计数据,比如通过 show table status 可以看到关于表的统计数据,通过 show index 可以看到关于索引的统计数据,那么这些统计数据是怎么来的呢?它们是以什么方式收集的呢?本章将聚焦于 InnoDB存储引擎 的统计数据收集策略,看

    2024年02月06日
    浏览(46)
  • 【CSS扩展】VUE如何使用或修改element plus中自带的CSS全局变量来定义样式

    目录 一、CSS声明全局变量 二、使用el plus 和 el ui的自带样式 1、element plus—— var.scss位置 2、element ui—— var.scss位置 三、修改el plus 和 el ui中的自定义样式变量(方法一致) 本萌新最近在写网页时使用到了element plus中自带的CSS全局样式定义,本文将从CSS声明全局变量的方法出

    2024年01月22日
    浏览(62)
  • 前端开发如何更好的避免样式冲突?级联层(CSS@layer)

    作者:vivo 互联网前端团队 - Zhang Jiqi 本文主要讲述了CSS中的级联层(CSS@layer),讨论了级联以及级联层的创建、嵌套、排序和浏览器支持情况。级联层可以用于避免样式冲突,提高代码可读性和可维护性。 我们参看Cascading and Inheritance Level 5(13 January 2022) 中6.4节所述: 级

    2024年02月06日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包