我所理解的Less的一些好处

  1. 函数式编程css
  2. 自定义变量用于整体主题调整
  3. 嵌套语法简化开发复杂度

mixin的写法

.defaultBorder(@width: 10px, @style: solid, @color: red){
border: @width @style @color;
}

when条件判断函数

.area(@width) when(@width <= 200px){
width: @width;
background-color: yellow;
}
@media screen and (max-width: 200px){
.when{
.area(100px);
}
}
@media screen and (min-width: 201px){
.when{
.area(210px);
}
}

loop循环函数

.widthFun(100);
.widthFun(@n, @i:10) when (@i <= @n){
width-@{i}{
width: (@i * 100% / @n);
}
.widthFun(@n,(@i+10))
} // 上面这段loop编程成css:
width-10 {
·width: 10%;
}
width-20 {
·width: 20%;
}
width-30 {
·width: 30%;
}
width-40 {
·width: 40%;
}
width-50 {
·width: 50%;
}
width-60 {
·width: 60%;
}
width-70 {
·width: 70%;
}
width-80 {
·width: 80%;
}
width-90 {
·width: 90%;
}
width-100 {
·width: 100%;
}

常用的数值计算函数

// unit()对数值连接单位/去除单位
width: unit(@num, px); // round()对数值四舍五入取整数
width: round(@num); // ceil()对数值向下取整数
width: ceil(@num); // floor()对数值向上取整数
width: floor(@num); // percentage()把小数转化为百分比
width: percentage(@num); // abs()对数值取绝对值
width: unit(abs(@num)); // lighten()颜色提亮
color: lighten(@color, 10%); // darken()颜色变暗
background-color: darken(@bgColor, 20%);

Less的匹配模式(类似于函数重载)

// 示例:方向不同的样式三角形
.sanjiao(down ,@w: 100px, @c:#ff6600){
border-width: @w;
border-color: @c transparent transparent transparent;
border-style: solid;
}
.sanjiao(top ,@w: 100px, @c:#ff6600){
border-width: @w;
border-color: transparent transparent @c transparent;
border-style: solid;
}
.sanjiao(left ,@w: 100px, @c:#ff6600){
border-width: @w;
border-color: transparent @c transparent transparent;
border-style: solid;
}
.sanjiao(right ,@w: 100px, @c:#ff6600){
border-width: @w;
border-color: transparent transparent transparent @c ;
border-style: solid;
}
#tranigle{
width: 0;
height: 0;
overflow: hidden;
.sanjiao(right)
}

Less中的论据

直接使用函数默认数值

.border(@s: solid, @c :#ff6600, @h:10px){
border: @arguments;
}

Less中免编译

具体的使用场景就是calc在less中的使用,calc在scss中可以按照css的样式直接去写

.width{
// css3中的计算属性 calc
width: calc(300px * 0.3);
// ~'XXX'指示less不要编译XXX而是直接把XXX写入css文件中
width: ~'calc(300px * 0.3)';
}

Less中的!important

.sss{
width: 100px;
height: 100px;
border: 10px;
}
.box{
// 编译成css后,每个.sss中的属性后面都加上了 !important
.sss !important;
}

Less中的其他函数

可以参考官网的文档详细学习

Less在实际应用中的注意事项

Less中运算符号都会被计算,使用属性一些特殊值的时候会出现一些问题

这个示例是在做egg形状的时候需要用到的属性,如果直接使用/会导致50% / 60% 被计算成为0.8333333%显示在样式中,这样就会出现问题,

所以需要使用转义符来保证这个属性的值原样输出,一开始做的时候没有注意到这点,搜索less转义符

看到这个介绍才反应过来

// border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
border-radius: ~"50% 50% 50% 50% / 60% 60% 40% 40%";

Less在Vue中使用的时候需要在main.js中注册,Sass不用

我是 fx67ll.com,如果您发现本文有什么错误,欢迎在评论区讨论指正,感谢您的阅读!

如果您喜欢这篇文章,欢迎访问我的 本文github仓库地址,为我点一颗Star,Thanks~

转发请注明参考文章地址,非常感谢!!!

工作中常用Less知识点实践总结的更多相关文章

  1. Java工作中常用到的工具

    刚看但网上一篇Java最流行工具的文章,结合自己日常应用总结一下开发工作中常用到的工具. 一,Java版本,jdk8,也是Java普及最快的版本,除了本身性能提升外,新增的函数式编程特性也让开发效率更 ...

  2. 工作中常用到的Java集合类有哪些?

    前言 只有光头才能变强. 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y Java集合是我认为在Java基础中最最重要的知 ...

  3. Git-【技术干货】工作中Git的使用实践

    Git-[技术干货]工作中Git的使用实践 置顶 2019-09-17 21:02:16 web洋仔 阅读数 11444更多 分类专栏: Git   版权声明:本文为博主原创文章,遵循CC 4.0 B ...

  4. 工作中常用的js、jquery自定义扩展函数代码片段

    仅记录一些我工作中常用的自定义js函数. 1.获取URL请求参数 //根据URL获取Id function GetQueryString(name) { var reg = new RegExp(&q ...

  5. 工作中常用的Linux命令:mkdir命令

    本文链接:http://www.cnblogs.com/MartinChentf/p/6076075.html (转载请注明出处) 在Linux系统中,mkdir命令用来创建一个目录或一个级联目录. ...

  6. 工作中常用的Linux命令:crontab命令

    本文链接:http://www.cnblogs.com/MartinChentf/p/6060252.html (转载请注明出处) crontab是一个用来设置.删除或显示供守护进程cron执行的定时 ...

  7. 工作中常用的Linux命令:ipcs/ipcrm命令

    本文链接:http://www.cnblogs.com/MartinChentf/p/6057100.html (转载请注明出处) ipcs 1. 命令格式 ipcs [resource-option ...

  8. 工作中常用的Linux命令:find命令

    本文链接:http://www.cnblogs.com/MartinChentf/p/6056571.html (转载请注明出处) 1.命令格式 find [-H] [-L] [-P] [-D deb ...

  9. 工作中常用的QTP操作Excel函数

    前言 本文只是对工作中常用的EOM相关函数的整理,并不是要写个大而全的操作手册,如果想对EOM有更多的了解可以参考QTP的帮助文档或查看QTP安装目录\CodeSamplesPlus\UsingExc ...

  10. 收集一些工作中常用的经典SQL语句

    作为一枚程序员来说和数据库打交道是不可避免的,现收集一下工作中常用的SQL语句,希望能给大家带来一些帮助,当然不全面,欢迎补充! 1.执行插入语句,获取自动生成的递增的ID值 INSERT INTO ...

随机推荐

  1. 深入分析C++对象模型之移动构造函数

    接下来我将持续更新"深度解读<深度探索C++对象模型>"系列,敬请期待,欢迎关注!也可以关注公众号:iShare爱分享,自动获得推文和全部的文章列表. C++11新标准 ...

  2. easyx的使用,鼠标交互(3.0)

    本文从B站学习,借鉴: 学习视频地址:鼠标操作(旧版)_哔哩哔哩_bilibili

  3. 2024-04-21:用go语言,给一棵根为1的树,每次询问子树颜色种类数。 假设节点总数为n,颜色总数为m, 每个节点的颜色,依次给出,整棵树以1节点做头, 有k次查询,询问某个节点为头的子树,一共

    2024-04-21:用go语言,给一棵根为1的树,每次询问子树颜色种类数. 假设节点总数为n,颜色总数为m, 每个节点的颜色,依次给出,整棵树以1节点做头, 有k次查询,询问某个节点为头的子树,一共 ...

  4. 《最新出炉》系列初窥篇-Python+Playwright自动化测试-38-如何截图-下篇

    1.简介 这个系列的文章也讲解和分享了差不多三分之一吧,突然有小伙伴或者童鞋们问道playwright有没有截图的方法.答案当然是:肯定有的.宏哥回过头来看看确实这个非常基础的知识点还没有讲解和分享. ...

  5. 第九課-Channel Study For Caller Client Api

    1.浏览Mirth Connect开放Client API 2.启动Vs2019,编程测试Client Api的调用 开启你在宇宙第一IDE下熟悉的.net之旅吧!

  6. KubeVela 上手(1)|让云端应用交付更加丝滑

    简介: KubeVela 是阿里云和微软共同发起的 OAM(Open Application Model)标准的技术实现,旨在打造统一.标准.跨环境的云端应用交付,省时省力,轻松简单 作者|KubeV ...

  7. 技术干货 | 闲鱼:一个优秀的 Push 平台,需要经历怎样的前世今生

    ​简介: mPaaS 消息推送服务,快速集成多家厂商 Push 通道,有效提高用户留存率,提升用户体验. 编者荐语: 点击这里,了解 mPaaS 消息推送服务,快速集成多家厂商 Push 通道,有效提 ...

  8. [PHP] 浅谈 Laravel Scout 的存在意义

    注:Laravel Scout 是官方支持的对框架模型数据进行全文检索功能的扩展包. Laravel 的 Scout 与 Eloquent ORM 进行了深度集成,不用开发者再自己进行代码侵入了. L ...

  9. [PHP] 浅谈 Laravel Authorization 的 gates 与 policies

    首先要区分 Authentication 与 Authorization,认证和授权,粗细有别. 授权(Authorization) 有两种主要方式,Gates 和 Policies. Gates 和 ...

  10. Rust中的并发性:Sync 和 Send Traits

    在并发的世界中,最常见的并发安全问题就是数据竞争,也就是两个线程同时对一个变量进行读写操作.但当你在 Safe Rust 中写出有数据竞争的代码时,编译器会直接拒绝编译.那么它是靠什么魔法做到的呢? ...