less 和 scss 对比使用

概念:

变量 语句 函数 继承
  1. 变量和插值 作用域

    less:
    @number:123px;
     
    @key:margin;
    
    @i :3;
    
    .box@{i}{
        width:@number;
        @{key}:auto;
    }
    
    sass:
    $number:123px;
    
    $key:margin;
    
    $i :3;
    
    .box#{$i}{
        width: $number;
        #{$key}:auto;
    }
    
  2. 嵌套 属性(sass)

    less:
    ul{
        list-style: none;
        li{
            float: left;
            div{
                width: 200px;
            }
        }
        &:hover{ //去除空格
            color:red;
        }
    }
    sass:
    ul{
        list-style: none;
        li{
            float: left;
            div{
                width: 200px;
            }
        }
        &:hover{ //去除空格
            color:red;
            font:{
                size:10px;
                weight:bold;
                family:宋体
            }
        }
    
    }
    
  3. 计算

    less:
    
    .box4{
        width: @number*3;
        height:@number+10;
        height:@number+10px;
    }
    
    .box4{
        width: @number*3;
        height:@number+10;
        height:@number+10px;
        height:@number + 10em; //不同单位运算,以运算符前面一个为准
        height:10em+@number;
        font:20px/1.5;
        padding:~"20px/1.5"; //禁止转义
        color:#010203*2;
    }
    
    sass:
    .box4{
         width: $number * 3;
        // height: $number + 10em;//报错 单位不同不能运算
        font: 20px / 1.5; //默认不支持
        padding:(20px/1.5); //可以添加小括号
        color:#010203*2;
     }
    
  4. 函数

    less:
    .box4{
        width: round(3.4px);
        height: percentage(0.2);
    }
    
    .box4{
        width: round(3.4px);
        height: percentage(0.2);
        margin: random();
        padding:sqrt(0.25px)
    }
    
    自定义函数:
    sass
    @function sum($n,$m){
        @return $n + $m;
    }
    
    .box5{
        font-size: sum(4px, 5px);
    }
    
  5. 混入

    less:
    
    .show{
        display: block;
    }
    
    .hide(){ //加括号后,不会被编译
        display: none;
    }
    
    .colorMy(@color){ //加括号后,不会被编译
        display: none;
        background-color: @color;
    }
    .box6{
        width:100px;
        .show;
        .hide;
        .colorMy(blue);
    }
    
    sass:
    @mixin show {
        display: block;
    }
    @mixin hide($color) {
        display: none;
        color:$color;
    }
    
    .block6{
        width: 100px;
        @include show;
        @include hide(red)
    }
    
  6. 命名空间

    less:
    #nm(){
        .show{
            display: inline-block;
        }
    }
    
    .box7{
        #nm.show;
    }
    
  7. 继承

    less:
    
    .line{
        display: inline;
    }
    .box8{
        &:extend(.line);
    }
    .box9{
        &:extend(.line);
    }
    以分组的形式编译:
    .line,
    .box8,
    .box9 {
      display: inline;
    }
    
    sass:
    .line{
        display: inline;
    }
    .box8{
        @extend .line;
    }
    .box9{
        @extend .line;
    }
    
    编译结果:
    .line, .box8, .box9 {
      display: inline;
    }
    
    
    %line{
        display: inline;
    }
    .box8{
        @extend %line;
    }
    .box9{
        @extend %line;
    }
    
    编译结果:
    .box8, .box9 {
      display: inline;
    }
    
  8. 合并与媒体查询

    less:
    .box10{
        background+: url(./1.jpg);
        background+: url(./2.jpg);
        transform+_: scale(2);
        transform+_: round(30deg);
    }
    编译后:
    .box10 {
      background: url(./1.jpg), url(./2.jpg);
      transform: scale(2) rotate(30deg);
    }
    
    sass:
    $background : (
        a : url(./1.jpg),
        b : url(./2.jpg)
    );
    $tramsform : (
        a : scale(2),
        b : rotate(30deg)
    );
    
    .box10{
        background : map-values($background);
        transform: zip(map-values($tramsform)...);
    }
    
    编译后:
    .box10 {
      background: url(./1.jpg), url(./2.jpg);
      transform: scale(2) rotate(30deg);
    }
    
  9. 媒体查询

    .box10{
        width: 100px;
        @media all and (min-width : 768px){
            width:600px;
        }
        @media all and (min-width : 1440px){
            width:900px;
        }
    }
    编译后:
    .box10 {
      width: 100px;
    }
    
    @media all and (min-width: 768px) {
      .box10 {
        width: 600px;
      }
    }
    
    @media all and (min-width: 1440px) {
      .box10 {
        width: 900px;
      }
    }
    
  10. 条件和 循环

    less:
    
    @count:5;
    .g(@cn) when (@cn>4){
        width: 100px + @cn;
    }
    
    .g(@cn) when (@cn<4){
        width:100px+@cn;
    }
    
    .box1{
        .g(@count);
    }
    
    sass:
    $count:5;
    .box11{
        @if ($count>4) {
           width:100px + $count; 
        }
        @else{
            width: 10px;
        }
    }
    
    less 循环: 递归调用
    @count2 : 0;
    .get2(@cn)when(@cn<3){
        .get2(@cn+1);
        .box-@{cn}{
            width:100px + @cn;
        }
    }
    
    .get2(@count2);
    
    sass:
    @for $i from 0 through 2 {
        .box-#{$i}{
            width:100px+$i;
        }
    }
    
  11. 导入

    @import './reset.scss'
    
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容

  • 1、LESS的官网:http://lesscss.org 2、Sass官网地址:http://sass-lang....
    Howie223阅读 3,677评论 0 5
  • Data Visualization with D3 D3: SVG中的jQurey 1. Add Documen...
    王策北阅读 759评论 0 2
  • 各种纯css图标 CSS3可以实现很多漂亮的图形,我收集了32种图形,在下面列出。直接用CSS3画出这些图形,要比...
    剑残阅读 9,532评论 0 8
  • 1. tab列表折叠效果 html: 能源系统事业部 岗位名称: 工作地点 岗位名...
    lilyping阅读 1,853评论 0 1
  • @转自GitHub 介绍一下标准的CSS的盒子模型?低版本IE的盒子模型有什么不同的?(1)有两种, IE 盒子模...
    YT_Zou阅读 1,309评论 0 1