认识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配置的更多相关文章

  1. 认识less和webstrom的less配置

    认识less和webstrom的less配置 今天完成的事情: 首先第一件事情是,整理一下常用的颜色摄取 #F1F1F1 google的设置页面的body的背景颜色 #FFF 为google的内容块的 ...

  2. Sass简介,安装环境,Sass的语法格式及编译调试

    什么是 CSS 预处理器? 定义:CSS 预处理器定义了一种新的语言,其基本思想是,用一种专门的编程语言,为 CSS 增加了一些编程的特性,将 CSS 作为目标生成文件,然后开发者就只要使用这种语言进 ...

  3. vue -- 使用sass并引入公共sass文件

    sass可以提高我们的开发效率,怎么在vue的项目中使用sass并且可以设置一些公共的文件呢? 使用sass 1.安装sass的依赖包 npm install --save-dev sass-load ...

  4. Sublime Text 3编译Sass - Sublime Text安装Sass插件

    1.首先要安装sass,安装流程: http://www.w3cplus.com/sassguide/install.html 2.sublime text安装Package Control(已经安装 ...

  5. sass安装:webpack sass编译失败,node-sass安装失败的终极解决方

    文章来源:sass安装:webpack sass编译失败,node-sass安装失败的终极解决方 sass难言之隐-sass安装的坑 之前花了很多时间折腾node-sass,发现sass老是安装不上 ...

  6. 安装Ruby、Sass在WebStrom配置Scss编译环境css自动压缩

    安装Sass和Compass sass基于Ruby语言开发而成,因此安装sass前需要安装Ruby.(注:mac下自带Ruby无需在安装Ruby!) window下安装SASS首先需要安装Ruby,先 ...

  7. 安装Ruby、Sass在WebStrom添加Watcher实现编辑scss文件时自动生成.map和压缩后的.css文件

    前言 这段时间一直在看Bootstrap,V3官方直接提供了Less版本的源码,就先将Less学完了,很简单的语法,学习写Demo都是在Webstorm里写的,配置了Watcher自动编译(详见< ...

  8. webstrom 使用sass的环境配置说明

    sass(https://www.sass.hk)基于Ruby语言开发而成,因此安装sass前需要安装Ruby.(注:mac下自带Ruby无需在安装Ruby!) 一.安装ruby 注意勾选第二个选项 ...

  9. Sass 入门 (一) 安装Sass

    Sass安装 ruby安装 因为sass依赖于ruby环境,所以装sass之前先确认装了ruby.先导官网下载个ruby 在安装的时候,请勾选Add Ruby executables to your ...

随机推荐

  1. 如何用phpcms将静态网页生成动态网页?

    在前两篇随笔中已经简单介绍了phpcms,那么现在让我们来看一下如何用phpcms将静态网页生成动态网页? 1.在templates文件夹下新建模板文件夹ceshi(名字可以自己随笔起) 2.在ces ...

  2. 一篇文章带你快速入门createjs

    开始用createjs这个框架的时候,发现网上的相关教程还是挺少的,所以写一篇文章,方便日后查看.   createjs简介 官网:http://www.createjs.cc/ createjs中包 ...

  3. php添加pcntl扩展(Linux)

    pcntl扩展可以支持php的多线程操作(仅限linux)原本需要重新编译PHP的后面configrue提示加上--enable-pcntl 由于我的php是采用yum安装的,所以不能采用上面的方式下 ...

  4. Linux常用操作命令(一)

    java程序员要学习一些linux知识 java程序员要学习一些linux知识,下面就是您要学的命令:大型J2EE应用都在建构在linux环境下的.开发环境下我们可以通过samba映射成本地的网络驱动 ...

  5. 【Android Developers Training】 27. 序言:和其它应用交互

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  6. 实现excel导入导出功能,excel导入数据到页面中,页面数据导出生成excel文件

    今天接到项目中的一个功能,要实现excel的导入,导出功能.这个看起来思路比较清楚,但是做起了就遇到了不少问题. 不过核心的问题,大家也不会遇到了.每个项目前台页面,以及数据填充方式都不一样,不过大多 ...

  7. 利用java反射机制编写solr通用的java客户端

    一.前言 通过上一篇的讲解,我们知道了dynamicFiled字段,它是动态的,不需要显示的声明.而且一些常用的基本类型solr已经默认给我们创建好了. 例如:*_i,*_is,等. 如果我们要使用动 ...

  8. IOS开发基础环境搭建

    一.目的 本文的目的是windows下IOS开发基础环境搭建做了对应的介绍,大家可根据文档步骤进行mac环境部署: 二.安装虚拟机 下载虚拟机安装文件绿色版,点击如下文件安装 获取安装包:       ...

  9. dynamic-load-apk 插件与宿主方法互调

    新建项目 DlPluginHost,下载dynamic-load-apk源码 1.将dynamic-load-apk 文件夹中的lib做为module导入到DlPlginHost 2.导入到Plugi ...

  10. tcp/ip通信传输流

    利用TCP/IP协议族进行网络通信时,会通过分层顺序与对方进行通信,发送端从应用层往下走,接收端则往应用层方向走. 我们用HTTP进行举例 客户端在应用层发出想要看到某个web页面的http请求.HT ...