Less Less基础

1.less

less是一种动态样式语言,属于CSS预处理器的范畴,它扩展了CSS语言,增加了变量,Mixin,函数等特性,使CSS更易维护和扩展。Less既可以在客户端上运行,也可以借助Node.js在服务端运行。

2.Less中的注释

(1).以//开头的注释,不会被编译到css文件中

(2).以/**/包裹的注释会被编译到css文件中

3.Less中的变量

(1).使用@来声明一个变量:@pink:pink,@selector:#box;

(2).作为普通属性值来使用:直接使用@pink

(3).作为选择器、属性名和url:使用@{selector}的形式

@color:deeppink;

@idname:#box;

@optionName:width;

.......................

@{idname}{

position: relative;

@{optionName}: 300px;

..........................

.inner{

..........................

background-color: @color;

...........................

}

}

(4).变量的延迟加载

@color:deeppink;

@idname:#box;

@optionName:width;

@var:1;

@{idname}{

...........................

.inner{

...........................

background-color: @color;

@var:0.5;

opacity: @var; // opacity: 0.3;

@var:0.3;

}

opacity: @var; // opacity: 1;

}

4.less的嵌套规则

(1).基本嵌套规则

LESS 嵌套遵循 "父级选择器包含子级选择器" 的逻辑,对应 HTML 中的父子元素关系。

(2).&的使用

& 避免生成后代选择器。

@color:deeppink;

@idname:#box;

@optionName:width;

@var:1;

@{idname}{

position: relative;

@{optionName}: 300px;

height: 400px;

border: 1px solid #000;

margin: auto;

.inner{

..........................

background-color: @color;

..........................

&:hover{ // 生成#box .inner:hover,不使用&则生成#box .inner :hover

background-color: pink;

}

}

5.避免编译

#box{

width: ~"calc(100px + 100px)"; //提示less这里不用编译,让原生css计算

// height: 100px + 100px; //less编译过后为200px

height: 100px + 100em; //less编译过后为200px,less运行出的单位是less遇到的第一个单位,是纯数值运算,不考虑单位转换

background: red;

}

css 复制代码
@color:deeppink;
@idname:#box;
@optionName:width;
@var:1;
*{
	margin: 0;
	padding: 0;
}
@{idname}{
	position: relative;
	@{optionName}: 300px;
	height: 400px;
	border: 1px solid #000;
	margin: auto;
	background-color: skyblue;
	.inner{
		width: 100px;
		height: 100px;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		background-color: @color;
		margin: auto;
		@var:0.5;
		opacity: @var;
		@var:0.3;
		
		&:hover{
			background-color: pink;
		}
	}
	opacity: @var;
}
相关推荐
东风西巷1 小时前
PDFgear:免费全能的PDF处理工具
前端·pdf·软件需求
森之鸟1 小时前
Mac电脑上如何打印出字体图标
前端·javascript·macos
mCell2 小时前
GSAP 入门指南
前端·javascript·动效
gnip2 小时前
组件循环引用依赖问题处理
前端·javascript
Aotman_3 小时前
el-input textarea 禁止输入中文字符,@input特殊字符实时替换,光标位置保持不变
前端·javascript·vue.js·前端框架·es6
Nan_Shu_6143 小时前
Web前端面试题(1)
前端·面试·职场和发展
lypzcgf3 小时前
Coze源码分析-资源库-创建知识库-前端源码-核心组件
前端·typescript·react·coze·coze源码分析·ai应用平台·agent开发平台
百思可瑞教育4 小时前
在Vue项目中Axios发起请求时的小知识
前端·javascript·vue.js·北京百思教育
患得患失9494 小时前
【个人项目】【前端实用工具】OpenAPI to TypeScript 转换器
前端·javascript·typescript
大前端helloworld4 小时前
前端梳理体系从常问问题去完善-基础篇(html,css,js,ts)
前端·javascript·面试