文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何在css中自定义属性

2023-06-08 08:03

关注

本篇文章给大家分享的是有关如何在css中自定义属性,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

1* css变量的语法

<1> 什么是css变量?

如果您使用过任何一种编程语言,那么您应该已经熟悉了变量的概念。 变量允许您存储和更新程序所需的值以便工作。

在CSS中使用变量的好处与在编程语言中使用变量的好处并没有太大的不同。

以下是规范对此的说法:

[Using CSS variables] makes it easier to read large files, as seemingly-arbitrary values now have informative names, and makes editing such files much easier and less error-prone, as one only has to change the value once, in the custom property, and the change will propagate to all uses of that variable automatically.

W3C Specification .

[使用CSS变量]可以更容易地读取大文件,因为看似任意的值现在具有信息性名称,并且使得编辑此类文件更容易且更不容易出错,因为只需要在自定义属性中更改一次值 ,这种更改将自动传播到所有使用该变量的地方。

<2>css自定义变量语法

要声明变量而不是常用的CSS属性(如颜色或填充),只需提供以 - - 开头的自定义命名属性:

.box{  --box-color: #4d4e53;  --box-padding: 0 10px;}

属性的值可以是任何有效的CSS值:颜色,字符串,布局值,甚至是表达式。

以下是一些有用的自定义属性:

:root{  --main-color: #4d4e53;  --main-bg: rgb(255, 255, 255);  --logo-border-color: rebeccapurple;  --header-height: 68px;  --content-padding: 10px 20px;  --base-line-height: 1.428571429;  --transition-duration: .35s;  --external-link: "external link";  --margin-top: calc(2vh + 20px);    --foo: if(x > 5) this.width = 10;}

如果您不确定 :root,在HTML中它与html相同但具有更高的特异性,相当于全局变量。

<3> css变量的使用

var() 函数

您要通过 var() 这个 css 函数来使用 css 变量,将 css 变量名传入这个函数:

.box{  --box-color:#4d4e53;  --box-padding: 0 10px;  padding: var(--box-padding);}.box div{  color: var(--box-color);}

var() 函数的语法是:
 

var( <custom-property-name> [, <declaration-value> ]? )

方法的第一个参数是要替换的自定义属性的名称。函数的可选第二个参数用作回退值。如果第一个参数引用的自定义属性无效,则该函数将使用第二个值。

如果您不确定是否已定义自定义属性并且想要提供用作回退的值,则可以执行此操作。

例如:

color: var(--foo, red, blue); //将red, blue同时指定为回退值;即是说任何在第一个逗号之后到函数结尾前的值都会被考虑为回退值。

padding: var(--box-padding, var(--main-padding));

calc()函数

由于我们习惯使用预处理器和其他语言,我们希望在处理变量时能够使用基本运算符。 为此,CSS提供了一个calc()函数,它使浏览器在对自定义属性的值进行任何更改后重新计算表达式:

:root{  --indent-size: 10px;  --indent-xl: calc(2*var(--indent-size));  --indent-l: calc(var(--indent-size) + 2px);  --indent-s: calc(var(--indent-size) - 2px);  --indent-xs: calc(var(--indent-size)/2);}

如果您尝试使用无单位值,则使用calc()函数可以带来很大的方便:

:root{  --spacer: 10;}.box{  padding: var(--spacer)px 0;   padding: calc(var(--spacer)*1px) 0; }

css自定义属性的scop

自定义属性也遵守CSS层叠规则。
 

2* 利用js使用css自定义属性

假设您有一个名为 --left-pos 的 CSS 变量,其值为 100px,范围为 CSS 文档中的 .sidebar 类:

.sidebar {--left-pos: 100px;}

可以通过如下方式获取 --left-pos 的值:

const sidebarElement = document.querySelector('.sidebar');const cssStyles = getComputedStyle(sidebarElement);const cssVal = String(cssStyles.getPropertyValue('--left-pos')).trim();console.log(cssVal); //100px

设置css属性值:

sidebarElement.style.setProperty('--left-pos', '200px');

3* css 变量和预处理变量有什么不同?

在样式化网站时,您可能通过使用Sass和Less等预处理器来使得变量的更具有灵活性。

预处理器允许您设置变量,并在函数,循环,数学运算等中使用它们。这是否意味着CSS变量无关紧要?

不完全是,主要是因为CSS变量与预处理器变量不同。

差异源于CSS变量是在浏览器中运行的真正的CSS属性,而预处理器变量需要被编译成常规CSS代码,因此浏览器对它们一无所知。

这意味着您可以更新样式表文档中的CSS变量,内联样式属性和SVG表示属性,或者选择使用JavaScript 动态 操作它们。对于 CSS 自定义属性的修改,会立马传递到使用到他的地方,而预处理器则无法完成这种行为,因为他们是提前已经编译好了的!

这并不是说你需要在一个或另一个之间做出选择:没有什么能阻止你利用CSS和预处理器变量一起工作的超能力。

什么是css

css是一种用来表现HTML或XML等文件样式的计算机语言,主要是用来设计网页的样式,使网页更加美化。它也是一种定义样式结构如字体、颜色、位置等的语言,并且css样式可以直接存储于HTML网页或者单独的样式单文件中,而样式规则的优先级由css根据这个层次结构决定,从而实现级联效果,发展至今,css不仅能装饰网页,也可以配合各种脚本对于网页进行格式化。

以上就是如何在css中自定义属性,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯