速通sass基础语法

速通Sass语法:

sass的特点:

由于css的缺陷:无法自定义变量,不可引用,嵌套等。sass/scss/less等css预处理器产生。以sass为例,引入了变量、嵌套、运算、混入(Mixin)、继承、颜色处理、函数等诸多功能。方便css的开发维护。

变量

使用变量

sass 复制代码
div {
  color: $blue;
}

插值使用变量#{$var}

sass 复制代码
$side: left;
$my-radius: 5px;
.rounded {
  border-#{$side}-radius: $my-radius;
}
其中 border-#{$side}-radius: $my-radius; 渲染结果为:border-left-radius: 5px;

运算

sass 复制代码
$var: 100px;
body {
  margin: (14px/2);
  top: 50px + 100px;
  right: $var * 10%;
}

嵌套

sass 复制代码
body{
	h3{
	  top:10px;
	}
}

注释

sass 复制代码
/* 块注释 */
// 行注释

混入(Mixin)

sass 复制代码
@mixin bordered {
  border-top: dotted 1px black;
  border-bottom: solid 2px black;
}
#menu a {
  color: #111;
  @include bordered;
}
.post a {
  color: red;
  @include bordered;
}

函数

sass 复制代码
@function double($n) {
  @return $n * 2;
}
#sidebar {
  width: double(5px);
}

判断逻辑

if-else

sass 复制代码
$color: red;
p {
  color: $color;
  @if $color == red {
    background-color: #000;
  } @else {
    background-color: #fff;
  }
}
for/while/each
sass 复制代码
@for $i from 1 to 10 {
  .border-#{$i} {
    border: #{$i}px solid blue;
  }
}
$i: 6;
@while $i > 0 {
  .item-#{$i} { width: 2em * $i; }
  $i: $i - 2;
}

@each $member in a, b, c, d {
  .#{$member} {
    background-image: url("/image/#{$member}.jpg");
  }
}
其中.#{$member} 是#{$member}字符串插值写法。

继承

sass 复制代码
.class1 {
  border: 1px solid #ddd;
}

.class-sub {
  @extend .class1;
  font-size: 120%;
}
相关推荐
木斯佳23 分钟前
鸿蒙开发入门指南:前端开发者快速掌握常用布局
前端·css
咕噜咪25 分钟前
OpenLayers 入门教程:从零开始学习Web地图开发
前端·学习
炽烈小老头28 分钟前
前端最最最基础的基础HTML基础
前端·html
小霖家的混江龙39 分钟前
仿淘宝 AI 推荐:用 Next.js 构建入门智能水果推荐 Demo
前端·人工智能·next.js
诚诚程程成44 分钟前
URL Query Editor 前端开发工具:方便调试页面URL参数 URL参数可视化
前端
CHU7290351 小时前
直播逛购新体验——直播商城APP前端功能详解
前端·小程序
Jackson__1 小时前
Agent Skill 和 MCP 到底有什么区别?很多人搞混了
前端·ai编程·mcp
new code Boy2 小时前
Vue2转Vue3速查表
前端·javascript·vue.js
紫_龙2 小时前
最新版vue3+TypeScript开发入门到实战教程之toRefs与toRef实用技巧
前端·javascript·typescript
大家的林语冰2 小时前
Vite 第 1 个 Rolldown 稳定版正式发布,前端构建又一波“工业革命“
前端·javascript·vite