手把手带你了解sass
sass的使用
减少重复的工作
1.变量的声明:
是以$开头给变量命名;
$height-color: #F30
2.变量的使用范围:
变量可以在多个地方存在,不一定限制在代码块中。但是如果定义在了代码块中,则只能在代码块中使用。
先在外面或者上面给属性命名,在使用的地方应用这些变量。
3.变量的命名:
命名:以下划线或者横杠都看自己的意愿,中划线更普遍。(大部分下划线和横杠是互通的,但是类名和ID名不一定。
4.sass的嵌套使用:
sass的嵌套:支持多层嵌套,避免重复书写相同的类名或者ID名。
注意:
父选择器标识符:&
1.连接伪元素:
&会直接被父级元素替换
- article a {
- color: blue;
- :hover { color: red }
- }
-
- =>artical a {color:blue}
- artical a :hover{color:red}
- artical a{
- color:blue;
- &:hover{color:red}
- }
如果使用伪元素需要用&来连接,不然就直接识别成后代元素,会和父元素有一个空格导致样式与预期不符。
2.群组选择器的嵌套
将重复的元素提出来:
- .container{
- h1,h2,h3{margin-bottom:10px}
- }
- =>
- .container h1, .catainer h2, .container h3{margin-bottom:10px}
3.组合选择器>,+,~
1.>
:选中元素的直接子元素(只有一个元素)
2.+
:选中同层相邻元素(所有+后面相同的元素)
3.~
:选中所有在~前相同层级的~后的元素
5.嵌套属性
- nav{
- border:{
- style:solid;
- width:1px;
- color:#ccc
- }
- }
- =>
- nav{
- border-style:solid;
- border-width:1px;
- border-color:#ccc;
- }
6.导入sass文件
1.@import
css中也有该规则,但是只有执行到@import时才会去下载导入的css文件;加载过慢
sass无需发起额外的下载请求;@import时就解析成了css;
color.scss => @import "color"
注意:可以省略后缀名
2.使用部分sass文件
如果以下划线开头命名则不会单独编译输出css
3.默认变量
!default
4.注意
如果以css结尾
导入的是一个URL地址
导入的是url()
=>生成的文件是直接被浏览器解析了的,可能会造成额外下载
6.注释
静默注释://
不会暴露在浏览器中
普通注释:/* */
7.混合器
1.使用场景:
1.有大段样式代码需要重复使用=>将重复代码抽离出来成一个逻辑单元
2.能用通用的名字将这个混合器的功能描述出来;(语义化)
`rounded-corners
2.标识符:
@mixin
@include
3.使用方法:
- //相当于将这个样式封装起来了
- @mixin rounded-centers{
- -moz-border-radius:5px;
- -webkit-border-radius:5px;
- border-radius:5px;
- }
- //使用这个样式
- notice{
- background-color:green;
- border:2px solid #ccc;
- @include round-center
- }
4.规则
1.如果混合器通过@include
包含在父规则中时,会生成嵌套规则
2.可以使用&
5.给混合器传参
类似于function
- @mixin link-colors($normal, $hover, $visited){
- color:$normar;
- &:hover{color:$hover}
- &:visited{color:$visited}
- }
- a{
- @include(red,blue,green)
- }
- a{
- @include link-colors($normal:red,$hover:blue,$visited:green)
- }
6.默认参数值
声明:$name:default-value
8.选择器继承
1.定义:选择器可以继承为另一个选择器的所有样式
2.语法:@extend
- .error{
- border:1px solid red;
- background-color:#fdd;
- }
- .seriousError{
- @extend .error;
- border-width:3px;
- }
后写的属性样式可以覆盖先写的;
3.继承何时选择
当一个元素拥有的类是属于另一个类时
继承比起混合器生成的代码更少,有利提高站点速度
当不同的规则被应用到同一个元素上时,先看选择器的权重,如果权重相同则后面的覆盖前面的
避免多后代时应用继承选择器.foo .bar{@extend .error}
手把手带你了解sass的更多相关文章
- [.Net] 手把手带你将自己打造的类库丢到 NuGet 上
手把手带你将自己打造的类库丢到 NuGet 上 序 我们习惯了对项目右键点击“引用”,选择“管理NuGet 程序包”来下载第三方的类库,可曾想过有一天将自己的打造的类库放到 NuGet 上,让第三者下 ...
- 手把手带你做一个超炫酷loading成功动画view Android自定义view
写在前面: 本篇可能是手把手自定义view系列最后一篇了,实际上我也是一周前才开始真正接触自定义view,通过这一周的练习,基本上已经熟练自定义view,能够应对一般的view需要,那么就以本篇来结尾 ...
- Android性能优化:手把手带你全面实现内存优化
前言 在 Android开发中,性能优化策略十分重要 本文主要讲解性能优化中的内存优化,希望你们会喜欢 目录 1. 定义 优化处理 应用程序的内存使用.空间占用 2. 作用 避免因不正确使用内 ...
- Android:手把手带你深入剖析 Retrofit 2.0 源码
前言 在Andrroid开发中,网络请求十分常用 而在Android网络请求库中,Retrofit是当下最热的一个网络请求库 今天,我将手把手带你深入剖析Retrofit v2.0的源码,希望你们会喜 ...
- [转帖]从零开始入门 K8s | 手把手带你理解 etcd
从零开始入门 K8s | 手把手带你理解 etcd https://zhuanlan.zhihu.com/p/96721097 导读:etcd 是用于共享配置和服务发现的分布式.一致性的 KV 存储系 ...
- 手把手带你阅读Mybatis源码(三)缓存篇
前言 大家好,这一篇文章是MyBatis系列的最后一篇文章,前面两篇文章:手把手带你阅读Mybatis源码(一)构造篇 和 手把手带你阅读Mybatis源码(二)执行篇,主要说明了MyBatis是如何 ...
- GitHub 热点速览 Vol.26:手把手带你做数据库
作者:HelloGitHub-小鱼干 摘要:手把手带你学知识,应该是学习新知识最友好的姿势了.toyDB 虽然作为一个"玩具"项目不能应用在实际开发中,但通过它你可以了解到如何制作 ...
- 手把手带你体验鸿蒙 harmonyOS
wNlRGd.png 前言 本文已经收录到我的 Github 个人博客,欢迎大佬们光临寒舍: 我的 GIthub 博客 学习导图 image.png 一.为什么要尝鲜 harmonyos? wNlfx ...
- Java开发不懂Docker,学尽Java也枉然,阿里P8架构师手把手带你玩转Docker实战
转: Java开发不懂Docker,学尽Java也枉然,阿里P8架构师手把手带你玩转Docker实战 Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一 ...
随机推荐
- C++入门经典-例6.20-修改string字符串的单个字符
1:使用+可以将两个string 字符串连接起来.同时,string还支持标准输入输出函数.代码如下: // 6.20.cpp : 定义控制台应用程序的入口点. // #include "s ...
- EBS 清除高速缓存
以R12.1.3为例: 以 “功能管理员 ”职责打开OAF界面 然后依次点击“核心服务”->“高速缓存结构”->“全局配置”->“清除所有高速缓存”->“是”,即可
- leetcode-easy-listnode-237 Delete Node in a Linked List
mycode # Definition for singly-linked list. # class ListNode(object): # def __init__(self, x): # sel ...
- 前端学习框架之layui
学习地址:https://www.layui.com/demo/laytpl.html
- 清除表单input输入框内数据
清除表单input输入框内数据 1. $(':input','#addVoucherType') //'#addVoucherType'表单id .not(':button') .val('') .r ...
- Nginx负载均衡服务器实现会话粘贴的几种方式
1. 使用Nginx 的ip_hash作为负载均衡服务并支持Session sticky 2. 使用nginx sticky第三方模块实现基于cookie的负载均衡 3.使用nginx的map指令根据 ...
- MM相关号码范围IMG设定
一.定义各物料类型的号码范围——MMNR 路径:後勤系統 - 一般 > 物料主檔> 基本設定 > 物料類型 >定義各物料類型的號碼範圍 2.定义供应商主档记录号码范围——OMS ...
- unity shader 波动圈
c# //////////////////////////////////////////// // CameraFilterPack - by VETASOFT 2018 ///// /////// ...
- CSS未完
CSS介绍 CSS(Cascading Style Sheet,层叠样式表)定义如何显示HTML元素. 当浏览器读到一个样式表,它就会按照这个样式表来对文档进行格式化(渲染). CSS语法 CSS实例 ...
- [ASP.NET] [JS] GridView点击高亮当前选择行,并在点击另一行时恢复上一选择行背景颜色
在ASP.NET中的gridview控件里面可以通过设定其OnRowDataBound事件来进行实现高亮当前行的操作 前端控件的设置: 只要设置好OnRowDataBound属性即可,会自动在.cs文 ...