Scss基础用法
2024-08-26 15:03:50
Scss基础用法
一、注释用法:
(1)//comment:该注释只是在.scss源文件中有,编译后的css文件中没有。
(2)/! /:重要注释,任何style的css文件中都会有,一般放置css文件版权说明等信息。
(3)/ /:该注释在compressed的style的css中没有,其他style的css文件都会含有。
二、变量:
1.一般以$开头,有作用域限制
$color: red;
.div{
background-color: $color;
}
2.若子选择器中定义的变量想成为全局变量,可以用!global
.div{
$width: 5px !global;
width: $width;
} .p{
width: $width;
}
3.嵌套引用,需#{}进行包裹
$left: left;
.div{
border-#{$left}-width: 5px;
}
4.计算
$left: 20px;
.div{
margin-left: $left + 12px;
margin-top: $left / 2;
}
三、选择器
1.选择器嵌套(允许属性嵌套)
.div{
.span{
height: 12px;
}
.p{
border: {
color: red;
}
}
}
2.引用父元素(使用&符号)
.div{
&:hover{
cursor: pointer;
}
}
四、代码复用
1.继承(若在div2后再加一个div1,也会影响div2的属性)
.div1{
font-size: 14px;
}
.div2{
@extend .div1;
color: red;
}
2.引用外部的scss文件(文件路径建议用相对路径)
@import ‘ ./test.scss’;
3.Mixin与Include
//使用@mixin命令,定义一个代码块
@mixin left {
float: left;
margin-left: 5px;
} //使用@include命令,调用这个mixin代码块
div {
@include left;
}
五、参数
eg1:
@mixin common($value1, $value2, $defaultValue: 5px){
display: block;
margin-left: $value1;
margin-right: $value2;
padding: $defaultValue;
}
.div1{
font-size: 8px;
@include common(11px, 13px, 15px);
}
.div2{
font-size: 8px;
@include common(11px, 13px);
}
eg2:
//生成浏览器前缀。
@mixin rounded($vert, $horz, $radius: 10px) {
border-#{$vert}-#{$horz}-radius: $radius;
-moz-border-radius-#{$vert}#{$horz}: $radius;
-webkit-border-#{$vert}-#{$horz}-radius: $radius;
} //使用的时候调用:
#navbar li { @include rounded(top, left); }
#footer { @include rounded(top, left, 5px); }
六、条件语句
可以用@if(){}来判断,也可以用@if(){}@else来判断
@if lightness($color) > 30% {
background-color: #000;
} @else {
background-color: #fff;
}
七、循环语句
1.for循环
@for $i from 1 to 10 {
.border-#{$i} {
border: #{$i}px solid blue;
}
}
2.while循环
$i: 6;
@while $i > 0 {
.item-#{$i} { width: 2em * $i; }
$i: $i - 2;
}
3.each(类似于for)
@each $member in a, b, c, d {
.#{$member} {
background-image: url("/image/#{$member}.jpg");
}
}
八、函数
可以自定义函数
@function double($n) {
@return $n * 2;
} #sidebar {
width: double(5px);
}
最新文章
- 页面加载完成后加载多个函数的js完美解决方案
- 自制jquery可编辑的下拉框
- SpringMVC -rest风格修改删除
- 《转》---google面经
- Nginx模块开发时unknown directive ";echo";的处理
- SQL Server数据库学习笔记-设计表时应该考虑的因素
- Android SoundPool 的使用以及原理分析
- Jenkins slave image
- Flask 扩展 Flask-PyMongo
- 【LUOGU???】WD与积木 NTT
- Python学习—数据库篇之SQL语句
- Basic berkeley socket functions
- LwIP Application Developers Manual6---Application API layers
- lattice 作图 举例
- JS Window对象操作思维导图
- BZOJ.2194.快速傅立叶之二(FFT 卷积)
- load_1m
- PC端-上传头像并裁剪
- 关于H5 移动端css 文本超出时省略号 失效的问题
- s5_day14作业
热门文章
- R语言编程艺术#04#数据框(data.frame)
- Java list对象列表排序 实例
- SNF快速开发平台MVC-集成了百度开源项目echars
- Apache Spark 2.2.0 新特性详细介绍
- 物联网架构成长之路(5)-EMQ插件配置
- iOS开发 关于启动页和停留时间的设置
- Android Launcher分析和修改5——HotSeat分析
- 【iCore4 双核心板_ARM】例程三:EXTI中断输入实验——读取ARM按键状态
- GPT(保护分区)解决办法
- 模板, 保存&;发布