• less 里面的calc 和 运算符有什么区别 ?


    首先看下less 官网介绍的运算符

    运算(Operations)
    算术运算符 +、-、*、/ 可以对任何数字、颜色或变量进行运算。如果可能,算术运算符在加、减或比较之前会进行单位换算。计算的结果以最左侧操作数的单位类型为准。如果单位换算无效或失去意义,则忽略单位。无效的单位换算例如:px 到 cm 或 rad 到 % 的转换。

    // 数字转换为相同的单位

    @convert: 5cm + 10mm; // returns 6cm @conversion-2: 2 - 3cm - 5mm; //
    result is -1.5cm

    // conversion is impossible @incompatible-units: 2 + 5px - 3cm; // 结果是
    4px

    // 带变量的示例
    @base: 5%;
    @filler: @base * 2; // returns 10%
    @other: @base + @filler; // 结果是 15%

    乘法和除法不会转换数字。在大多数情况下这是没有意义的,一个长度乘以一个长度就得到一个区域,而 CSS 是不支持指定区域的。Less 会按照数字的原样进行操作,并将明确声明的单位类型分配给结果。

    @base: 2cm * 3mm; // 结果是6cm

    你还可以对颜色进行算术运算:

    @color: (#224488 / 2); // 结果是#112244
    background-color: #112244 + #111; // 结果是#223355

    但是,你可能会发现 Less 的 色彩函数 更有用。

    从 4.0 开始,不会使用 / 运算符在括号外执行除法。

    @color: #222 / 2; // 结果为 #222 / 2,而不是 #111
    background-color: (#ffffff / 16); //结果是#101010

    如果你希望始终起作用,可以更改 Math 设置,但不建议这样做。

    再看看calc 的介绍

    为了与 CSS 兼容,calc() 不会计算 Math 表达式,但会计算变量和嵌套函数中的 Math 表达式。

    使用坑点:
    1、没写空格

    /*错误写法*/
    div{
          width: calc(100%-50px);
    }
    /*正确写法*/
    div{
          width: calc(100% - 50px);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    这里错误写法中-两边没加空格,导致width不生效。但并不是所有运算符间都需要加空格,只有 + 和 - 需要加空格,因为运算允许负数的出现

    2、没写单位

    /*错误写法*/
    div{
          width: calc(0 + 100px);
    }
    /*正确写法*/
    div{
          width: calc(0px + 100px);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    3、单位不同时会被转换成相同单位

    .box {
      width: calc("100% - 50px") 转成了50%
    }
    使用转义
    .box {
      width: calc(~"100% - 50px")
    }
    
    
    从上面的使用上来看,calc 和  运算符的区别四似乎可以做到两个不同单位直接的转换。
    还有什么区别?欢迎评论区讨论
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
  • 相关阅读:
    13 最大子数组和
    Containerd-1.6.5 镜像命令空间和容器操作使用
    Taurus.MVC WebMVC 入门开发教程3:数据绑定Model
    浅谈中压系统母线弧光保护的必要性
    在Linux上安装Zookeeper集群(zookeeper-3.5.9)
    Java异常-Exception
    nvidia-1080服务器上离线安装mmdetection2.23步骤
    【从头构筑C#知识体系】1.7 运算符和表达式
    url后面直接拼接参数
    毫末AI DAY的智驾弹药:上有「世界模型」,下有3000元方案
  • 原文地址:https://blog.csdn.net/MissXu666/article/details/132983969