cssLess语言介绍

今天小编给大家分享的是css Less 语言的详细介绍,相信大部分人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,话不多说,一起往下看吧。

我们提供的服务有:成都网站设计、网站建设、微信公众号开发、网站优化、网站认证、广汉ssl等。为1000+企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的广汉网站制作公司

 一、什么是Less

  css的Less好比是js的Jquery,可以让人们更方遍快捷的使用css,使css代码更简洁,可以减少重复的代码,减少开发人员的工作量。

Less CSS是一种动态样式语言,属于CSS预处理语言的一种,它使用类似CSS的语法,为CSS赋予了动态语言的特性,如变量、继承、运算、函数等,更方便CSS的编写和维护。

二、编译工具

1.Koala:国人开发的LESS/SASS编译工具

下载地址:

2.Node.js库

3.浏览器端使用

三、koala配置及使用

1.新建后缀为.less文件:index.less

头部写上:@charset "utf-8";   //设定字符集

2.把文件夹拖到koala中,设置输出路径为style下的index.css

  使用koala进行编译,然后就生成了一个index.css文件。

3.之后我们只要编辑index.less文件即可。

四、注释

1./*编译后会被保留*/

2.//编译后不会被保留

五、变量

1.设定变量:

@text_width: 300px;

2.使用变量:示例如下

.box{
  width: @text_width;
  height: @text_width;
  background: #000;
}

六、混合

1.混合简介:与原有的在class中新追加class的方法有所不同(原有

),使用Less的混合功能后,只要声明.border后,在.box中加  入.border;即可。

使用示例一:

.box{
  width: @text_width;
  height: @text_width;
  background: #000;

.border;
}

.border{

border: 5px solid yellow;

}

使用示例二:新增一个box2,但是它和box1只有一点点细微的区别,可以直接拿来box1使用,然后加上它自己的样式。

.box2{

.box1;

margin-left: 100px;

}

2.混合是可以带参数的

在index.less中使用带参数的值,在border_02后面加一个(),里面声明一个变量;

然后传入参数30px。

css Less 语言介绍

在编译后的index.css文件中,带参数的变量不显示

css Less 语言介绍

3.混合也可以带默认值

在border_03后面加一个(),里面声明一个变量,变量后面附一个初始值“:10px”;

如果不想用默认值,只要在text_hunhe下的border_03的()中写入值即可。

默认值必须带(),不然会报错。

css Less 语言介绍

4.混合高级使用示例,兼容性也可以使用

css Less 语言介绍

在编译后的index.css文件中,展示如下

css Less 语言介绍

七、匹配模式

1.简介:相当于js中的if,但不完全是

2.示例

先介绍一个画倒三角的方法

.sanjiao{
  width: 0;
  height: 0;
  overflow: hidden;
  border-width: 10px;
  border-color: red transparent transparent transparent;
  border-style: solid dashed dashed dashed;
}

匹配模式示例一:

.triangle(top,@w:5px,@c:#ccc){

border-width: @w;

border-color: @c transparent transparent transparent;

border-style: solid dashed dashed dashed;

}

.triangle(right,@w:5px,@c:#ccc){

border-width: @w;

border-color:  transparent @c transparent transparent;

border-style:  dashed solid dashed dashed;

}

.triangle(bottom,@w:5px,@c:#ccc){

border-width: @w;

border-color:  transparent transparent @c transparent;

border-style:  dashed dashed solid dashed;

}

.triangle(left,@w:5px,@c:#ccc){

border-width: @w;

border-color:  transparent transparent transparent @c;

border-style:  dashed dashed dashed solid;

}

.triangle(@_,@w:5px,@c:#ccc){    // @_ 是固定格式,表示不管你匹配到谁,都会带上这些内容

width: 0;
  height: 0;
  overflow: hidden;

}

.sanjiao{

.triangle(right,100px);

}

匹配模式示例二:

匹配模式定位

.pos(r){position:relative;}
.pos(a){position:absolute;}
.pos(f){position:fixed;}
.posi{
  width: 100px;
  height: 100px;
  background: blue;
  .pos(r);
}

八、运算

1.less中的运算可以是任何数字、颜色、变量,运算要包裹在括号中。如:+ - * /

2.示例如下:

@test_01:300px;

.box_02{

width: (@test_01 - 20) * 5;   //未强制规定必须要带px单位,只要有一个带即可

color: #ccc - 10;                      //不太常用到

}

九、嵌套规则

1.示例

css Less 语言介绍 

原css 

.list{}
.list li{}
.list a{}
.list span{}

使用Less嵌套:

.list{
  width: 600px;
  margin: 30px auto;
  padding: 0;
  list-style: none;
  font-size: 16px;    li{

height: 30px;
    line-height: 30px;
    background: blue;
    margin-bottom: 5px;
    padding: 0 10px;
  }
  a{
    float: left;
    color: #000;

&:hover{    //&代表上一层选择器

color: red;

}
  }
  span{
    float: right;
  }
}

十、arguments变量

.border_arg(@w:30px,@c:#ccc,@xx:solid){border:@arguments}     //省了一点点事儿,懒人必备

.test_arguments{.border_arg(40px);}

十一、避免编译、!important

1.避免编译:在我们需要输入一些不正确的css语法或者使用一些less不认识的专有语法时使用。在字符串前加上一个~即可

.test_03{
  width: ~'calc(300px - 30px)';    //~'...'避免编译,把单引号里的内容按照原样传给浏览器
}

2.!important关键字:适合用来调试,一般不会用到

.test_important{

.box !important;    //给所有样式加上!important

}

关于css Less语言就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果喜欢这篇文章,不如把它分享出去让更多的人看到。


标题名称:cssLess语言介绍
文章转载:http://myzitong.com/article/poiejd.html