总所周知,CSS不是一种编程语言,它可以开发网页的样式,但是由于没有变量、条件语句等程序员眼中的“编程元素”,所以写CSS是一件非常“不爽”的事情。
举个栗子:
.one {
padding-top: 20px;
padding-bottom: 20px;
padding-left: 30px;
color: #1e1e1e;
}
.two {
padding-top: 20px;
color: #1e1e1e;
}
看到此情此景,身为程序员的你,是不是很想把color: #1e1e1e;
这行代码抽出来?比如说定义一个redColor变量的值为#1e1e1e
目前业界已经有"好事者"为CSS加入一个名为"CSS预处理器"(css preprocessor)的东西,目的是为了添加编程元素。
"CSS预处理器"的基本思想:用一种专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件
SASS正是这个思想驱动下的产物,也是目前较为流行,优点较多的编程语言。而SCSS称为SASS的升级版,主要的区别在于编写的文件后缀和格式有所不同:
在Weex工程中,可以比较合适地支持SCSS,只需要规避CSS在Weex中的使用规则即可。
在标准的weex工程里面,需要先安装几个依赖:
npm install node-sass;
npm install sass-loader; //依赖node-sass
配置loader,打开webpack.config.js,修改loader,此处loader用于解析.scss文件:
loaders: [
{
test: /\.scss$/,
loader: "css!sass", //这样写样式和脚本会混在一个文件,也就是不分离样式,webpack有插件可以实现分离样式
exclude: /node_modules/
}
]
用 import 或 require 引入的sass文件进行加载,以及声明的内部样式进行加载,两种方式可以同时使用
<style lang="sass">
//方式一:import
@import "./foo.scss";
//方式二:直接写sass语法样式
</style>
踩过的坑:目前无法在<script>里面通过require的方式来加载scss文件,不建议如下用法:
<script>
require("./foo.scss")
</script>
变量
$red : #1875e7;
.component {
color : $red;
}
选择器嵌套
div h1 {
color : red;
}
div {
hi {
color:red;
}
}
属性嵌套
.one {
border: { //border后面必须加上冒号
color: red;
}
}
// 在嵌套的代码块内,可以使用&引用父元素。比如a:hover伪类,可以写成:
.two {
&:hover { color: #dcdcdc; }
}
计算功能
.tabbar {
margin: (88px/4);
top: 50px - 100px;
height: $var * 17%;
}
注释
颜色函数
// SASS提供了一些内置的颜色函数,以便生成系列颜色
lighten(#cc3, 10%) // #d6d65c
darken(#cc3, 10%) // #a3a329
grayscale(#cc3) // #808080
complement(#cc3) // #33c
插入文件
// @import命令,用来插入外部文件
@import "path/filename.scss";
// 如果插入的是.css文件,则等同于css的import命令
@import "foo.css";
代码的重用
继承
.class1 { // 定义一个class1
border: 2px solid #1e1e1e;
}
.class2 { // 使用@extend命令,让class2继承class1
@extend .class1;
font-size:80%;
}
Mixin
// 使用@mixin命令,定义一个代码块,类似于给样式添加一个标签,标记这个样式可以复用
@mixin right {
float: right;
margin-right: 20px;
}
// 使用@include命令,调用这个mixin。
.one {
@include right;
}
// mixin还可以指定参数和缺省值
@mixin right($value: 20px) { // $value为right的参数,缺省值为20px
float: right;
margin-left: $value;
}
// 调用时根据需要加入实参
.two {
@include left(40px);
}
// 有了mixin,我们可以抽象出不同属性中的相同内容,通过参数形式传递,比如以下场景:生成浏览器前缀
@mixin rounded($vert, $horz, $radius: 20px) {
border-#{$vert}-#{$horz}-radius: $radius;
-moz-border-radius-#{$vert}#{$horz}: $radius;
-webkit-border-#{$vert}-#{$horz}-radius: $radius;
}
// 以上代码调用方式
.one { @include rounded(top, left); }
.two { @include rounded(top, left, 5px); }
高级用法
// 可以使用@if用来判断
.one {
@if 1 + 1 == 2 { border: 1px solid; }
@if 5 < 3 { border: 2px dotted; }
}
// 还可以配套上@else
@if lightness($color) > 50% {
background-color: #dcdcdc;
}
@else {
background-color: #ffffff;
}
* 循环语句
```scss
// 支持for循环
@for $i from 1 to 10 {
.border-#{$i} {
border: #{$i}px solid red;
}
}
// 支持while循环
$i: 6;
@while $i > 0 {
.item-#{$i} { width: 4em * $i; }
$i: $i - 3;
}
// each命令,作用与for类似
@each $item in a, b, c, d {
.#{$item} {
background-image: url("/image/#{$item}.jpg");
}
}
```
* 自定义函数
```scss
@function treble($n) {
@return $n * 3;
}
#sidebar {
width: treble(5px);
}
```
原网址: 访问
创建于: 2022-01-15 12:42:12
目录: default
标签: 无
未标明原创文章均为采集,版权归作者所有,转载无需和我联系,请注明原出处,南摩阿彌陀佛,知识,不只知道,要得到
java windows火焰图_mob64ca12ec8020的技术博客_51CTO博客 - 在windows下不可行,不知道作者是怎样搞的 监听SpringBoot 服务启动成功事件并打印信息_监听springboot启动完毕-CSDN博客 SpringBoot中就绪探针和存活探针_management.endpoint.health.probes.enabled-CSDN博客 u2u转换板 - 嘉立创EDA开源硬件平台 Spring Boot 项目的轻量级 HTTP 客户端 retrofit 框架,快来试试它!_Java精选-CSDN博客 手把手教你打造一套最牛的知识笔记管理系统! - 知乎 - 想法有重合-理论可参考 安宇雨 闲鱼 机械键盘 客制化 开贴记录 文本 linux 使用find命令查找包含某字符串的文件_beijihukk的博客-CSDN博客_find 查找字符串 ---- mac 也适用 安宇雨 打字音 记录集合 B站 bilibili 自行搭建 开坑 真正的客制化 安宇雨 黑苹果开坑 查找工具包maven pom 引用地 工具网站 Dantelis 介绍的玩轴入坑攻略 --- 关于轴的一些说法 --- 非官方 ---- 心得而已 --- 长期开坑更新 [本人问题][新开坑位]关于自动化测试的工具与平台应用 机械键盘 开团 网站记录 -- 能做一个收集的程序就好了 不过现在没时间 -- 信息大多是在群里发的 - 你要让垃圾佬 都去一个地方看难度也是很大的 精神支柱 [超级前台]sprinbboot maven superdesk-app 记录 [信息有用] [环境准备] [基本完成] [sebp/elk] 给已创建的Docker容器增加新的端口映射 - qq_30599553的博客 - CSDN博客 [正在研究] Elasticsearch, Logstash, Kibana (ELK) Docker image documentation elasticsearch centos 安装记录 及 启动手记 正式服务器 39 elasticsearch 问题合集 不断更新 6.1.1 | 6.5.1 两个版本 博客程序 - 测试 - bug记录 等等问题 laravel的启动过程解析 - lpfuture - 博客园 OAuth2 Server PHP 用 Laravel 搭建带 OAuth2 验证的 RESTful 服务 | Laravel China 社区 - 高品质的 Laravel 和 PHP 开发者社区 利用Laravel 搭建oauth2 API接口 附 Unauthenticated 解决办法 - 煮茶的博客 - SegmentFault 思否 使用 OAuth2-Server-php 搭建 OAuth2 Server - 午时的海 - 博客园 基于PHP构建OAuth 2.0 服务端 认证平台 - Endv - 博客园 Laravel 的 Artisan 命令行工具 Laravel 的文件系统和云存储功能集成 浅谈Chromium中的设计模式--终--Observer模式 浅谈Chromium中的设计模式--二--pre/post和Delegate模式 浅谈Chromium中的设计模式--一--Chromium中模块分层和进程模型 DeepMind 4 Hacking Yourself README.md update 20211011
Laravel China 简书 知乎 博客园 CSDN博客 开源中国 Go Further Ryan是菜鸟 | LNMP技术栈笔记 云栖社区-阿里云 Netflix技术博客 Techie Delight Linkedin技术博客 Dropbox技术博客 Facebook技术博客 淘宝中间件团队 美团技术博客 360技术博客 古巷博客 - 一个专注于分享的不正常博客 软件测试知识传播 - 测试窝 有赞技术团队 阮一峰 语雀 静觅丨崔庆才的个人博客 软件测试从业者综合能力提升 - isTester IBM Java 开发 使用开放 Java 生态系统开发现代应用程序 pengdai 一个强大的博主 HTML5资源教程 | 分享HTML5开发资源和开发教程 蘑菇博客 - 专注于技术分享的博客平台 个人博客-leapMie 流星007 CSDN博客 - 舍其小伙伴 稀土掘金 Go 技术论坛 | Golang / Go 语言中国知识社区
最新评论