less可以做什么?less详解!(less嵌套选择器实现纯CSS二级导航)
前端技术众多,作为一名前端工程师,我们每接触新技术首先要懂得此技术的优势和劣势,这是最基本的。往深入了说还需要懂得技术的应用场景,与之配合的技术等,方便为以后架构做准备。而less作为一门CSS预处理语言,拥有函数式变成的特点,主要优点就是高效。主要适用于包含众多CSS的大型项目。主要体现在:项目公共样式的定义,如页面主色、固定数值(宽、高、时间等)、公用样式模板、封装省略浏览器兼容前缀的函数等。
1.less的两种使用方式
1.1 直接调用需要引入less.js,和less样式文件,需要注意的是rel需要指定为stylesheet\less。此方式也是在浏览器内部最终将less中的样式转换成css样式之后调用。因页面加载时资源请求较多,故不推荐此方法。
<link rel="stylesheet/less" href="./lessTest.less"/>
<script src="./less.js"></script>
1.2 将less文件编译为css文件后引入,博主使用的是考拉工具,大家可以自行百度。
less语法(本文为了方便将直接使用引入lessTest.less文件的方式,实际开发中建议使用第二种方式)
2. 定义变量 @变量名:变量值;
///定义颜色变量
@pe_color:#204d90; .div1{
width: 100px;
height: 100px;
background: @pe_color;
}
//定义字符串变量
@baseUrl:"./img/";
.div1{
width: 1000px;
height: 1000px;
background-image: url("@{baseUrl}/bannerNBA.jpg");
}
变量计算
*数值计算
@width:1000px; .div1{
width: @width;
height: @width/2;
margin-top: @width*pi(); //pi()为less函数,详细请查看API
border: 1px solid #000;
}
*颜色计算
@baseColor: #6dffa7;
@bdColor:spin(@baseColor,180);
.div1{
width: 1000px;
height: 1000px;
border: 10px solid @bdColor; //调色盘颜色数值旋转180度,也就是圆心对称点
background: darken(@baseColor,50%); //变暗50%
color:lighten(@baseColor,40%) //变亮40%
}
3. Mixin混合模板 定义模板: .模板名(参数){}
.myborder(@bdwidth,@bdstyle,@bdcolor){
border: @bdwidth @bdstyle @bdcolor;
}
.div1{
width: 1000px;
height: 1000px;
.myborder(5px,dashed,#666666)
}
*定义默认值
.myborder(@bdwidth:10px,@bdstyle:solid,@bdcolor:#86ffff){
border: @bdwidth @bdstyle @bdcolor;
}
.div1{
width: 1000px;
height: 1000px;
.myborder()
}
.myborder(@bdwidth:10px,@bdstyle:solid,@bdcolor:#86ffff){
border: @bdwidth @bdstyle @bdcolor;
}
.div1{
width: 1000px;
height: 1000px;
.myborder(20px)
}
*选择性调用
/*写兼容模板*/
.myTransition(){
-webkit-transition: all 1s linear;
-moz-transition: all 1s linear;
-ms-transition: all 1s linear;
-o-transition: all 1s linear;
transition: all 1s linear;
}
/*模板A-1*/
.myLinearBackground(style1,@color1,@color2){
background-image:-webkit-linear-gradient(top,@color1,@color2);
background-image:-moz-linear-gradient(top,@color1,@color2);
background-image:-ms-linear-gradient(top,@color1,@color2);
background-image:-o-linear-gradient(top,@color1,@color2);
opacity:.3;
}
/*模板A-2*/
.myLinearBackground(style2,@color1,@color2){
background-image:-webkit-linear-gradient(bottom,@color1,@color2);
background-image:-moz-linear-gradient(bottom,@color1,@color2);
background-image:-ms-linear-gradient(bottom,@color1,@color2);
background-image:-o-linear-gradient(bottom,@color1,@color2);
opacity:.7;
}
.myLinearBackground(@_,@_,@_){ //@_的数量要与两个样式模板参数数量相同
.myTransition(); //@_为通配符,此模板意味只要调用.myLinearBackground(),内部样式无论何时都会调用
}
.div1{
width: 1000px;
height: 1000px;
.myLinearBackground(style1,#86ffff,#ff3e54);
}
.div1:hover{
.myLinearBackground(style2,#ff3e54,#86ffff)
}
3. 嵌套选择器
用嵌套选择器完成一个纯CSS导航:
DOM结构如下:
<ul class="box">
<li>菜单1</li>
<li>菜单2
<ul>
<li>子菜单1</li>
<li>子菜单2</li>
<li>子菜单3</li>
<li>子菜单4</li>
</ul>
</li>
<li>菜单3</li>
<li>菜单4</li>
</ul>
CSS如下:
@bgcolor:#86ffff;
@bdcolor:#ffe91e;
@itemwidth:100px;
@itemheight:50px;
.itemBorder(@bdwidth:2px,@bdstyle:solid,@bdcolor:@bdcolor){
border: @bdwidth @bdstyle @bdcolor;
}
*{
margin:;
padding:;
}
.box{
width: 420px;
height: 50px;
list-style: none;
li{ //相当于ul li
width: @itemwidth;
height: @itemheight;
list-style: none;
line-height: 50px;
text-align: center;
background: @bgcolor;
.itemBorder();
&:hover{ //相当于ul li:hover
.itemBorder(2px,solid,#ff3516)
}
}
>li{ // 相当于ul>li
overflow: hidden;
float: left;
&:hover{ // 相当于ul>li:hover
overflow: visible;
cursor: pointer;
}
}
}
喜欢请点击右下角推荐,如有疑问可以留言。转载请标明出处。
less可以做什么?less详解!(less嵌套选择器实现纯CSS二级导航)的更多相关文章
- SATB深入详解与问题剖析【纯理论】
延着上一次[https://www.cnblogs.com/webor2006/p/11147893.html]的理论继续. SATB: 在G1中,使用的是SATB(Snapshot-At-The-B ...
- 使用 Jmeter 做 Web 接口测试-详解
接口测试概述 定义 WIKI定义:接口测试作为集成测 试的一部分,通过直接控制API来判断系统的功能性,可靠性,性能与安全性.API测试是没有界面的,执行在通讯 层.API 测试在自动化测试中有着重要 ...
- node.js + mongodb 做项目的详解(一)
想写博客很长时间了,因为一直身患懒癌,所以一直拖到了现在.markdown的语法也是刚刚学,试验一下效果好了不说了,直接上干货了.----------------------------------- ...
- python接口自动化(二)--什么是接口测试、为什么要做接口测试(详解)
简介 上一篇和大家一起科普扫盲接口后,知道什么是接口,接口类型等,对其有了大致了解之后,我们就回到主题-接口测试. 什么是接口测试 接口测试是测试系统组件间接口的一种测试.接口测试主要用于检测外部系统 ...
- node.js + mongodb 做项目的详解(二)
这次内容是结合bootstrap把登陆注册做好,还有就是express的中间件等问题. 看这篇博客之前建议先看我上篇写的那篇博客http://www.cnblogs.com/hubwiz/p/4118 ...
- mybatis 详解(九)------ 一级缓存、二级缓存
上一章节,我们讲解了通过mybatis的懒加载来提高查询效率,那么除了懒加载,还有什么方法能提高查询效率呢?这就是我们本章讲的缓存. mybatis 为我们提供了一级缓存和二级缓存,可以通过下图来理解 ...
- Css详解之(选择器)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 详解jQuery的选择器
1.基本选择器 基本选择器是jQuery中最常用的选择器,也是最简单的选择器,它通过元素id.class和标签名等来查找DOM对象.在网页中,每个id名称只能使用一次,class允许重复使用. ♠ # ...
- 《CSS权威指南》双鱼书详解——第二章选择器
一.基本规则 CSS的核心特性就是能向文档中的一组元素类型应用某些规则. 二.规则结构 选择器+声明块. h1{ color:red;background:yellow;} ,声明块由一个或多个声明组 ...
随机推荐
- 使用cordova开发app
前言 公司之前用的app就是一个套壳挂个链接就能用的app,后来需要添加微信分享方便传播,没办法只好做成混合式的app了, 因为之前做.net用vs可以创建cordova项目也试着玩过,就决定用cor ...
- 数字信号处理MATLAB简单序列
数字信号处理应用的几个基本序列: 1 单位样本序列 function mainImseq() clc clear disp('生成抽样序列'); y=imseq(,,); %调用样本函数,此时序列下标 ...
- 使用SBT编译Spark子项目
前言 最近为了解决Spark2.1的Bug,对Spark的源码做了不少修改,需要对修改的代码做编译测试,如果编译整个Spark项目快的话,也得半小时左右,所以基本上是改了哪个子项目就单独对那个项目编译 ...
- PHPCMS 概念初学
CMS是一个内容管理系统,主要是用来做企业站,也就是说我们在网上见到绝大部分的企业站都是用这个做的,有极少数的是用源生代码写的 如何安装? 1.从网站搜索下载安装包并解压 2.点击文件夹后显示一下两个 ...
- apache的用户认证
1. 限制用户访问的方式: 1. 限制访问服务的客户端主机 2. 需要用户名和密码 2. 行为用户验证需要两步: 1. 创建一个包含用户名和密码的文件 2. 服务器上的哪些资源需要保护,哪些用户可以进 ...
- 《JavaScript DOM 编程艺术》
前几天京东买了一本书,在豆瓣上好评如潮,买下了啃一啃,书名<JavaScript DOM 编程艺术>,在好好深造一下javaScript.一边啃,一边敲.当然应该要做好笔记.一些简单的就看 ...
- PKUSC2015总结
突然发现这是自己第100篇博客...写下总结庆祝一下好啦 首先就是..D类狗果真没人权啊啊啊.考的辛辛苦苦结果因为D类拿不到一个好协议真的是哭瞎辣QAQ 然后就是..自己真的是太弱啊啊啊..各种傻逼题 ...
- Spring+SpringMVC+MyBatis+easyUI整合基础篇(三)搭建步骤
框架介绍: 主角即Spring.SpringMVC.MyBatis.easyUI,大家应该也都有所了解,概念性的东西就不写了,有万能的百度. 工作环境: jdk 1.7 m ...
- [故障公告] 13:52-14:03,访问量突增,博客web服务器CPU 100%
13:52-14:03,由于访问量突增,博客web服务器全线CPU 100%,造成博客站点不正常访问,由此给您带来麻烦,请您谅解. 为了迎接访问量的增长给web服务器CPU带来的巨大压力,上周我们已经 ...
- 每天一个linux命令(47)--scp命令
scp是secure copy 的简写,用于在Linux 下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝而不能跨服务器,而且scp传输是加密的.可能会稍微影响一下速度.当 ...