SASS中自定义变量的使用是怎样,哪些事项要注意
Admin 2022-06-24 群英技术资讯 508 次浏览
SASS 中定义的变量,后设置的值会覆盖旧的值。
$color: red; $color: blue; .btn { color: $color; }
编译后为:
.btn { color: blue; }
如果你编写了一个 UI 库提供 SASS 文件,可能会提供一些参数供用户使用时自定义。而在 SASS 组件内部,我们需要应用上用户设置的这些值。但是如果使用者没有自定义变量的值,那这些变量应该有自己的默认值。
利用前面提到的覆盖机制是不能实现的。因为无论是你在 @import UI 库之前设置还是之后,都不能影响这个导入文件中的值。如果你设置的值在导入之前,那么 UI 库中的变量因为在后面,所以你的设置会被覆盖而不起作用;如果你的设置在导入之后,那更加不起作用了。
假设这是 UI 中的样式文件:
_lib.scss
$color: red; .btn { color: $color; }
在另一个文件中使用,并且试图自定义变量的值:
page.scss
@import 'lib'; $color: blue;
或:
page.scss
$color: blue; @import 'lib';
两者编译结果均为:
.btn { color: red; }
!default
针对这种情况,SASS 提供了 !default 标识。将该标识应用于变量值后面,表示如果该变量没有在其他地方定义或即便定义了但值为 null,那此处设置的默认值才生效,否则使用其他地方设置的那个值。
将上面 _lib.scss 进行改造:
_lib.scss
- $color: red; + $color: red!default; .btn { color: $color; }
使用:
$color: blue; @import "lib";
注意:需要将自定义的值先于 @import,否则也不生效。
此时编译结果将是想要的那样,应用上了外部自定义的变量值。
.btn { color: blue; }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
CSS 制作图表的内容我们之前也有了解过,但本文介绍的是响应式柱状图的实现,那么具体怎样实现呢?下面我们就一起了解看看怎样用CSS Grid布局来制作一个普通的响应式柱状图,实现效果如下。
目录一、背景二、什么是css原子化,又有什么用?1.含义分析2.方案选择三、开发体验可行性优点1.开发的效率和舒适2.灵活和可维护缺点1.仍存在的上手门槛2. 小程序使用windicss受
什么是盒子呢?拿下举例,我们可以把每个红框都比作一个盒子,他们可以是任意的HTML元素。盒子模型所谓盒子模型:就是把HTML页面中的布局元素看作是一个矩形的盒子,也就...
在css中,向左偏移的样式是“transform:translate(-向左偏移距离值);”;transform属性的作用是允许我们对元素进行旋转、缩放、移动或倾斜操作,translate()函数的作用是定义元素的平移转换。
这篇文章给大家分享的是用CSS3实现毛玻璃效果的内容,小编觉得挺实用的,能使得页面很生动,美化网页,因此分享给大家做个参考,文中示例代码介绍的很详细,感兴趣的朋友接下来一起跟随小编看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008