我们一般所使用的Less跟Sass一般是将其编译成我们所熟悉的CSS再导入使用,当然不经编译,直接在浏览器使用

我是习惯用Koala来进行编译,简单智能方便,Hbuilder也自带编译功能,不过要手动,比较麻烦

首先我们来说一下Less。

【Less中的变量】
1.声明变量使用 @变量名:变量值;
2.使用变量 @变量名
>>less中的变量类型:
①数字类 1 10px ②字符串:无引号字符串 red 和有引号字符串"gdak"
③颜色类 red #000000 rgb()
④值列表类型,用逗号或空格分隔
>>变量使用原则 :
多次频繁出现的值、需要修改的值设为变量
 
3.混合(MiXins)
①无参混和声明 :.name{} 调用:选择器中调用
②带参混合
无默认值声明: .name(@param){} 调用:.name(parValue); parValue不可以省略
有默认值声明: .name(param:value()){} 调用:name(parValue); parValue可以省略
>>无参混合会在CSS中编译同名的class选择器;有参的不会
4.Less的匹配模式
使用混合进行匹配,类似于if结构:
声明
.name(条件一,参数){}
.name(条件二,参数){}
.name(@_,参数){}
调用: .name(条件值,参数值);
匹配规则:根据调用时提供的条件值,去寻找与之匹配的miXin执行,其中@_表示永远需要执行的部分
5.Less中的运算
*+-/可带单位可不带
颜色运算时,红绿蓝分三组计算,组内可进位,组间互不干涉。
6.Less中的嵌套:保留HTML中的代码结构,
嵌套默认后代选择器,如果需要子代选择器,则在子代前面加>
&表示上一层,&:hover 表示上一层的hover事件
 
 
 
section p {
color: red;
background-color: blue;
text-align: center;
}
section ul {
padding: 0px;
list-style: none;
}
section ul li {
float: left;
margin: 10px;
width: 100px;
text-align: center;
border: 1px solid #000000;
}
section ul li:hover {
background-color: yellowgreen;
}

当然,我们最看好less的一点可能就是它的嵌套了就像上边要写这么长的代码,使用less来写就如以下代码所示,是不是看着舒服了很多,用编译器编译完就可以显示为上边代码的样子了

section{
p{
color: red;
background-color: blue;
text-align: center;
}
ul{
padding: 0px;
list-style: none;
li{
float: left;
margin: 10px;
width: 100px;
text-align: center;
border: @bod;
&:hover{
background-color: yellowgreen;
}
}
}
}

下边来说与一下Sass

1. SASS中的变量
使用 $变量名:变量值 声明变量
如果变量名需要在字符串中嵌套,则需使用#加大括号包裹:
2.sass中的运算会将单位也进行运算,使用时需注意最终单位:
例:10px*10px=100px*px
3.sass中的嵌套: 选择器的嵌套 属性嵌套 伪类嵌套
选择器的嵌套 ul{li{}}后代
ul{>li{}}子代
&表示上一层 div{ul{li{&=-=div ul li}}}
属性嵌套 :属性名与大括号之间必须有: 例如boder:{color:red;}
伪类嵌套: ul{li{&:hover{"ul li :hover"}}}
4. 混合宏、继承、占位符
①混合宏:声明@mixin name($param:value){}
调用:@include name(value)
》》声明时,可以有参可以无参;可带默认值,但调用必须符合生命规范
>>优点:可以传参,不会生成同名class
>>缺点:会将混合宏的代码copy到对于那个的选择器中
②继承: 声明: .class{} 调用: @extend .class
>>优点:继承的相同代码会提取到并集选择器中,减少冗余代码,
>>缺点:无法进行传参,会在CSS中生成一个同名class
③占位符:声明:%class{} 调用: @extend %class
>>优点:继承相同代码,会提到并集选择器,不会生成同名的class选择器;
>>缺点:无法进行传参
 
综上所述:当要传递参数时用混合宏,当有现成class时用继承,不须参数不需class时候用占位符
5.if条件结构:
@if 条件{}
@else 条件{}
6.for循环结构
@for $i from 1 to 10{} 不含十;
@for $i from 1 through 10{} 含十;
7.while循环结构
$j:1;
@while $j<10{
.while井{$j}{
boder:井{$j}px solid red;
}
$j:$j+1;
}
8.each循环遍历
@each item in a,b,c,d{
//item 表示每一项
}
9、函数:
@function func($length){
$length: $length*5;
@return $length;
}
调用:func(10px);
 

相信都能看出sass与less的不同了,定义变量Less用的是@符,Sass用的是$符当然,sass可以用if条件结构,循环结构,定义函数比less高大上了许多。所以一般还是用sass来写,以备以后不时之需

CSS预处理语言——less与sass的使用的更多相关文章

  1. css预处理语言--让你的css编写更加简单方便

    CSS预处理语言之一-------LESS Less 是一门 CSS 预处理语言,它扩展了 CSS 语言,增加了变量.Mixin.函数等特性,使 CSS 更易维护和扩展. Less 可以运行在 Nod ...

  2. CSS预处理语言

    CSS预处理语言 Less,Sass,Stylus 安装 Less yarn add less 运行命令 ./node_modules/.bin/lessc 嵌套规则 Less.Sass嵌套规则一样 ...

  3. Less:Less(CSS预处理语言)

    ylbtech-Less:Less(CSS预处理语言) Less 是一门 CSS 预处理语言,它扩充了 CSS 语言,增加了诸如变量.混合(mixin).函数等功能,让 CSS 更易维护.方便制作主题 ...

  4. CSS预处理语言-less 的使用

    Less 是一门 CSS 预处理语言,它扩展了 CSS 语言,增加了变量.Mixin.函数等特性,使 CSS 更易维护和扩展. Less 可以运行在 Node 或浏览器端. Less的编译处理 作为一 ...

  5. CSS 预处理语言之 less 篇

    less 前言 Less 是一门 CSS 预处理语言,它扩充了 CSS 语言,增加了诸如变量.混合(mixin).函数等功能,让 CSS 更易维护.方便制作主题.扩充. 安装 客户端使用 // 引入 ...

  6. css预处理语言的模块化实践

    编写css是前端工作中,一项普通而又频繁的劳动,由于css并不是一门语言,所以在程序设计上显得有些简陋.对于小型项目来说,css的量还不至于庞大,问题没有凸显,而如果要开发和持续维护一个较为大型的项目 ...

  7. CSS预处理器之less和sass

    CSS预处理器 1.        基于CSS的另一种语言 2.        通过工具编译成CSS 3.        添加了很多CSS不具备的特性 4.        能提升CSS文件的组织方式 ...

  8. LESS,强大的CSS预处理语言

    虽然写的css不多,但是我已经切身感觉到了书写css的恶心...抛开最令人烦的浏览器兼容问题不说,这个语言本身就有不少问题. 最简单的,比如多个地方是同一个颜色的,如果可以写在一个样式里还没什么,但是 ...

  9. CSS 预处理语言之 Scss 篇

    简介 1. Sass 和 Scss Sass 和 Scss 其实是同一种东西,我们平时都称之为 Sass:Scss 是 Sass 3 引入新的语法,其语法完全兼容 CSS3,并且继承了 Sass 的强 ...

随机推荐

  1. jQuery(20161108)

    jQuery的引入包必须要在其他引入包的最上方,否则会出错.因为如果在页面加载完成后还未执行jQuery包,那么jQuery的引入包就没用了 如果浏览器报错:Uncaught Error: Boots ...

  2. CSS用足够大的纯色内阴影去覆盖掉谷歌input记住账号或密码时默认出现的黄色背景

    在谷歌浏览器会默认记住账号,而记住账号之后其input的背景会变成黄色,解决的办法如下: input:-webkit-autofill { -webkit-box-shadow: 0px 1000px ...

  3. (11)连个工具类之间的比较4.Collections与Arrays

    集合框架中的工具类:特点:该工具类中的方法都是静态的. Collections:常见方法: 1, 对list进行二分查找: 前提该集合一定要有序. int binarySearch(list,key) ...

  4. (30)批处理文件.bat

    批处理文件(bat) 简单的说,批处理的作用就是自动的连续执行多条命令 .编写bat处理文件可以使用记事本的方式: 常见批处理文件的命令: echo 表示显示此命令后的字符 tiltle 设置窗口的标 ...

  5. Vue学习之路---No.7(分享心得,欢迎批评指正)

    老规矩,先回顾一下上回的重点: 1.对于input框,若为单选框,如果没有对其设置value,那么其checked的值将在true Or false之间切换:如果设置了value,那么将会切换valu ...

  6. 初见 ThreadLocal 类

    这个类能够将一个对象和一个线程绑定起来. 之所以写这个类是因为 DBUtils 工具类,在 JavaEE 经典三层结构中对于事务的操作,不方便放在 DAO 层,因为具有侵入性,只适合放在 Servic ...

  7. 利用echo命令实现倒计时的功能

    echo -e:启用反斜线控制字符的转换        -E:关闭反斜线控制字符的转换(预设如此)        -n:取消行末之换行符号(与 -e 选项下的 \c 字符同意 -e参数下的控制参数 \ ...

  8. Struts2之Validator

    Struts2中提供了数据校验验证数据例如验证邮件.数字等.验证方式有3种:一是通过validate()方法,二是通过Xml,三是使用注解方式. 一.初始化 首先定义一个User类 package c ...

  9. NTP时间服务器

    1. NTP简介 NTP(Network Time Protocol,网络时间协议)是用来使网络中的各个计算机时间同步的一种协议.它的用途是把计算机的时钟同步到世界协调时UTC,其精度在局域网内可达0 ...

  10. 【Egret】使用Egret开发的HTML5项目,使用本地电脑作为服务器进行移动端调试流程

    流程: 1.先开启本机IIS服务器 具体开启流程如下:http://www.jb51.net/article/29787.htm 2.添加服务器MIME类型, 按照以下两个教程把所有的MIME类型都添 ...