认识sass和webstrom的sass配置
认识sass和webstrom的sass配置
我纳闷啊!电脑死机,我刚才编写的内容全没了。
呵呵!
一.sass的使用
1.首先要到官网下载个稳定的ruby版本,因为sass运行是需要ruby环境
它安装的方法也不难。
只需要输入如下代码就行
gem install sass
2.接着在webstrom上设置,搜索栏输入file watchers,新建
然后根据相应的地方输入如下代码
program:
F:\Program Files (x86)\Ruby24-x64\bin\scss.bat
arguments:
--no-cache
--update
--sourcemap
--watch
$FileName$:$FileNameWithoutExtension$.css
output paths to refresh:
Output paths to refresh:$FileNameWithoutExtension$.css:$FileNameWithoutExtension$.css.map
3,一路确认就可以实现自动在scss文件下自动生成.css和.css.map文件了。
题外话:less实现在css文档下自动生成自动生成.css和.css.map文件,需要修改一下配置
arguments:
$FileName$
$FileParentDir$\css\$FileNameWithoutExtension$.css
--source-map
output paths to refresh:
lessc style.less ../css/style.css --source-map
二。认识 sass
它旧的版本是以缩进的形式编写的。
1.变量
Sass 的变量必须是 $ 开始,然后变量名和值使用冒号隔开,跟 CSS 的属性一致:
$base0:20px;
$base1:$base0+40px;
$global-color:blue;
header{
background:$global-color;
padding:$base1;
}
我是直接拷贝我前一份日记的代码,把@改为$.而生成的css样式是这样的:
header {
background: blue;
padding: 60px;
}
2.Mixins (混入)
sass中可用mixin定义一些代码片段,且可传参数,方便日后根据需求调用
先放出less的代码便于对比
@base0:20px;
@base1:@base0+40px; @global-color:blue; .bor-radius (@radius: 5px) {
border-radius: @radius;
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
} header{
background:@global-color;
padding:@base1;
.bor-radius(30px);
}
#div1{
background:pink;
.bor-radius;
}
而sass需要两个关键字@mixin @include来定义和调用函数
$base0:20px;
$base1:$base0+40px; $global-color:blue; @mixin bor-radius ($radius: 5px) {
border-radius: $radius;
-webkit-border-radius: $radius;
-moz-border-radius: $radius;
} header{
background:$global-color;
padding:$base1;
@include bor-radius(30px);
}
#div1{
background:pink;
@include bor-radius();
}
可以发现在less中,定义函数的方法是直接原生css的形式(以.xxx的形式定义函数的。)
.bor-radius (@radius: 5px) {
border-radius: @radius;
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
}
而sass中,则是
@mixin bor-radius ($radius: 5px) {
border-radius: $radius;
-webkit-border-radius: $radius;
-moz-border-radius: $radius;
}
在调用的时候,less直接调用
#div1{
background:pink;
.bor-radius;
}
而在sass中,是要使用@include关键字调用
#div1{
background:pink;
@include bor-radius();
}
而且sass是保留函数模式的(),而less默认参数时,是没有括号的。
3.继承
而在继承方面,我认为less更原生。更接近于css。无论是函数mixin还是继承都是直接嵌套调用。
而在sass还是需要使用关键字@extend
@extend来声明继承的。
#div1{
background:pink;
@include bor-radius();
}
header{
@extend #div1;
text-decoration: dashed;
}
生成的css
#div1, header {
background: pink;
border-radius: 5px;
-webkit-border-radius: 5px;
-moz-border-radius: 5px; } header {
text-decoration: dashed; }
3.嵌套和导入@import
嵌套和导入也没发现有什么不一样的。
bootstrap现在改用sass,而且现在sass一直在维护。我决定选择可口可乐(sass),而不选择百事可乐(less)
认识sass和webstrom的sass配置的更多相关文章
- 认识less和webstrom的less配置
认识less和webstrom的less配置 今天完成的事情: 首先第一件事情是,整理一下常用的颜色摄取 #F1F1F1 google的设置页面的body的背景颜色 #FFF 为google的内容块的 ...
- Sass简介,安装环境,Sass的语法格式及编译调试
什么是 CSS 预处理器? 定义:CSS 预处理器定义了一种新的语言,其基本思想是,用一种专门的编程语言,为 CSS 增加了一些编程的特性,将 CSS 作为目标生成文件,然后开发者就只要使用这种语言进 ...
- vue -- 使用sass并引入公共sass文件
sass可以提高我们的开发效率,怎么在vue的项目中使用sass并且可以设置一些公共的文件呢? 使用sass 1.安装sass的依赖包 npm install --save-dev sass-load ...
- Sublime Text 3编译Sass - Sublime Text安装Sass插件
1.首先要安装sass,安装流程: http://www.w3cplus.com/sassguide/install.html 2.sublime text安装Package Control(已经安装 ...
- sass安装:webpack sass编译失败,node-sass安装失败的终极解决方
文章来源:sass安装:webpack sass编译失败,node-sass安装失败的终极解决方 sass难言之隐-sass安装的坑 之前花了很多时间折腾node-sass,发现sass老是安装不上 ...
- 安装Ruby、Sass在WebStrom配置Scss编译环境css自动压缩
安装Sass和Compass sass基于Ruby语言开发而成,因此安装sass前需要安装Ruby.(注:mac下自带Ruby无需在安装Ruby!) window下安装SASS首先需要安装Ruby,先 ...
- 安装Ruby、Sass在WebStrom添加Watcher实现编辑scss文件时自动生成.map和压缩后的.css文件
前言 这段时间一直在看Bootstrap,V3官方直接提供了Less版本的源码,就先将Less学完了,很简单的语法,学习写Demo都是在Webstorm里写的,配置了Watcher自动编译(详见< ...
- webstrom 使用sass的环境配置说明
sass(https://www.sass.hk)基于Ruby语言开发而成,因此安装sass前需要安装Ruby.(注:mac下自带Ruby无需在安装Ruby!) 一.安装ruby 注意勾选第二个选项 ...
- Sass 入门 (一) 安装Sass
Sass安装 ruby安装 因为sass依赖于ruby环境,所以装sass之前先确认装了ruby.先导官网下载个ruby 在安装的时候,请勾选Add Ruby executables to your ...
随机推荐
- angularJS loading 载入画面
在请求网络的时候,显示loading画面 1. 使用http的interceptor,截断处理所有的http请求和响应,以及错误.在request的时候设置$rootScope.loading=Tru ...
- fpm 制作 rpm 包
支持的 源类型包 ① dir : 将目录打包成所需要的类型, 可用于源码编译安装软件包 ② rpm : 对 rpm 包进行转换 ③ gem : 对 rubygem 包进行转换 ④ python : 将 ...
- vue项目构建与实战
关于 微信公众号:前端呼啦圈(Love-FED) 我的博客:劳卜的博客 知乎专栏:前端呼啦圈 前言 由于vue相对来说比较平缓的学习过程和新颖的技术思路,使其受到了广大前后端开发者的青睐,同时其通俗易 ...
- LODOP之票据连续套打笔记<二>
接着上一篇博文,继续说说关于lodop,关于模板设计及相关的这里不多说了,上一篇博文最下面的推荐可以看看,说的很比较清楚,今天说说我在项目中运用套打实现分页预览和打印的, 之前弄lodop打印的时候发 ...
- cssradius
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- 类间调用inline函数的效率
问题描述: class A { public: int x, y, k, NY; inline int f(int i, int j, int k) {return ((i)*(NY + 1) * ...
- 关于XML(可扩展标记语言)的基础知识与写法
XML(Extensible Markup Language) HTML:超文本标记语言,主要用来展示 XML:可扩展标记语言,用来做数据传输XML特点:1.树状结构,有且只有一个根2.标签名自定 ...
- Linux 内核综述
一.什么是Linux内核: 内核->操作系统中最重要的部分,内核将在系统引导时被装载进RAM,其中包含了很多关键的例程,以操作系统.内核是OS最为关键的部分,人们常将OS(操作系统)与内核等同. ...
- ReOut
package JBJADV003;import java.io.*;public class ReOut { /** * @param args */ public static void main ...
- MD5加盐 Java加密算法
MD5带盐值的java加密算法 import java.security.MessageDigest; public class PasswordEncoder { private final s ...