您现在的位置是:网站首页> 编程资料编程资料
浏览器端如何使用LessLESS 让css也支持变量,运算符,include,嵌套规则等等 less让css具有动态语言的特性LESS 让css也支持变量,运算符,include,嵌套规则CSS less优化学习CSS预处理器:Sass和less进行对比Less里css表达式的写法示例介绍less开发指南
2021-09-06
1000人已围观
简介 这篇文章主要介绍了浏览器端如何使用Less,需要的朋友可以参考下
之前项目用过Less,现在负责的项目也要使用,所以就总结下Less,也方便以后查看。本文主要是讲浏览器端如何使用Less。
简介:
LESS是一种由Alexis Sellier设计的动态层叠样式表语言。LESS 是开源的,其第一个版本由Ruby写成,但在后续的版本当中,Ruby逐渐被替换为JavaScript。受益于JavaScript,LESS可以在客户端上运行(IE6+、Webkit、Firefox),也可以在服务端运行(Node.js、Rhino)。
本质上,LESS 包含一套自定义的语法及一个解析器,用户根据这些语法定义自己的样式规则,这些规则最终会通过解析器,编译生成对应的 CSS 文件。LESS 并没有裁剪 CSS 原有的特性,更不是用来取代 CSS 的,而是在现有 CSS 语法的基础上,为 CSS 加入程序式语言的特性。你也可以再less文件中写按照css规则写样式。
意义:
改变传统样式的编写方式,以面向对象的方式编写,提高开发效率。
引入LESS:
首先,引入rel属性的值是stylesheet/less的.less样式表。如下:
在渲染HTML页面时,less文件需要编译成css文件。我们可以有很多种方法。在服务器端,如Node.js,我们有专门的less编译模块。如果是在客户端,需要从LESS官网下载less.js文件,然后在HTML页面中引入,如下:
有了less编译工具,我们就可以渲染页面了。
在浏览器中使用less.js开发是很好的,但不推荐用于生产环境中。浏览器端使用是在使用LESS开发时最直观的一种方式。如果是在生产环境中,尤其是对性能要求比较高的场合,建议使用node或者其它第三方工具先编译成CSS再上线使用。
注意:
确保包涵.less样式表在less.js脚本之前
当你引入多个.less样式表时,它们都是独立编译的。所以,在每个文件中定义的变量、混合、命名空间都不会被其它的文件共享。
必须通过服务器环境访问页面,否则报错
浏览器选项:
你可以引入之前通过创建一个全局less对象的方式来指定参数,例如:
但是这影响所有初始链接标记。你也可以在指定的脚本标签的增加选项,如下:
或者,你也可以在链接配置参数覆盖某些选项,如下:
注意:
以上三种配置参数的优先级为:link标签的>script标签>全局对象
对象属性名称不驼峰
link标签的配置只和时间选项有关,其他不起作用
观察模式:
如果使用观察模式,则配置参数的env为development。然后在Less.js文件加载之后调用less.watch(),如下:
注意:
如果启动了观察模式,则浏览器会不断请求less文件,根据Last-Modified参数判断是否重新渲染页面,这会造成很大的性能消耗,所以在线上不要开启观察模式。如果是开发环境,这方便了我们观察效果。你也可以在href后面加上'#!watch'来触发观察模式。
完整demo:
reset.less是重置浏览器默认样式,config.js是浏览器选项的配置参数,如下:
config.js
less = {
env: "development", // or "production"
async: false, // load imports async
fileAsync: false, // load imports async when in a page under
// a file protocol
poll: 1000, // when in watch mode, time in ms between polls
functions: {}, // user functions, keyed by name
dumpLineNumbers: "all", // "comment" or "mediaQuery" or "all"
relativeUrls: false,// whether to adjust url's to be relative
// if false, url's are already relative to the
// entry less file
rootpath: ":/"// a path to add on to the start of every url
//resource
};
index.html
参数详解:
async
Type: Boolean
Default: false
是否异步加载重要文件
dumpLineNumbers
Type: String
Options: ''| 'comments'|'mediaquery'|'all'
Default: ''
如果设置了,这增加了源代码行信息输出的CSS文件。这有助于您调试,分析其中一个特定的规则是从哪里来的。
comments 选项用于输出user-understandable内容,
mediaquery 选项用于使用火狐插件解析css文件信息.
env
Type: String
Options: development or production
Default: depends on page URL
运行环境,如果是production,你的css文件将被缓存到本地并且信息不会输出到控制台。如果url以file://开头或者在你本地或者没有标准的端口,这都将被认为是development模式。
例如:
less = { env: 'production' };
errorReporting
Type: String
Options: html|console|function
Default: html
设置编译失败时错误报告的方法。
fileAsync
Type: Boolean
Default: false
当以file协议访问页面,是否异步引入文件
functions
Type: object
用户自定义函数
e.g.
less = {
functions: {
myfunc: function() {
return new(less.tree.Dimension)(1);
}
}
};
可以像Less函数一样使用它。
.my-class {
border-width: unit(myfunc(), px);
}
logLevel
Type: Number
Default: 2
在控制台输出日志的数量。如果是production环境,将不会输出任何信息。
2 - Information and errors1 - Errors0 - Nothing
poll
Type: Integer
Default: 1000
在观察模式下,测试的时间。
relativeUrls
Type: Boolean
Default: false
使用相对路劲。如果设置FALSE,则url是相对根目录文件。
globalVars
Type: Object
Default: undefined
全局变量列表注入代码。“字符串”类型的变量必须显式地包含引号。
less.globalVars = { myvar: "#ddffee", mystr: "\"quoted\"" };
这个选项定义了一个可以被文件引用的变量。这个变量也可以在文件中重新定义。
modifyVars
Type: Object
Default: undefined
Same format as globalVars.
与 globalVars参数含义相反,它将会在你文件最后定义,这意味着它将重写你在文件定义的。
rootpath
Type: String
Default: false
设置根目录,所有的Less文件都会以这个目录开始。
useFileCache
Type: Boolean
Default: true (previously false in before v2)
是否要使用每个会话文件缓存。缓存文件可以使用modifyVars,并且它不会再次检索所有文件。如果您使用观察模式或调用刷新加载设置为true,那么运行之前缓存将被清除。
相关内容
- 动态的样式语言less语法详解之混合属性LESS 让css也支持变量,运算符,include,嵌套规则等等 less让css具有动态语言的特性LESS 让css也支持变量,运算符,include,嵌套规则CSS less优化学习CSS预处理器:Sass和less进行对比Less里css表达式的写法示例介绍less开发指南CSS Less框架基础教程LESSCSS让CSS使用起来更加灵活成就CSS动态化
- CSS3属性background-size使用指南CSS3 background-image颜色渐变的实现代码CSS3混合模式mix-blend-mode/background-blend-mode简介css3实现一个div设置多张背景图片及background-image属性实例演示CSS的background属性及CSS3的背景图片设置总结使用CSS3来实现滚动视差效果的教程css3中背景尺寸background-size详解详解background属性的8个属性值(面试题)
- 分享一个2014年圣诞节倒计时页面特效纯js实现圣诞节在线动态倒计时效果源码2014年圣诞节倒计时网页的制作过程jQuery+css3制作精美的2020圣诞节倒计时页面动画特效代码
- 使用css3实现的tab选项卡代码分享多种动画形式的TABs选项卡的CSS3代码CSS3+jQuery实现切换过程中带有动态滑动展示的选项卡Tab效果jQuery+css3实现的超酷无图片圆角tab选项卡切换效果基于jquery+css3实现的Tabs带图形按钮选项卡切换纯CSS3实现的干净清爽tab选项卡切换特效源码
- 使用css3实现的windows8开机加载动画CSS3制作了一个动画导航效果(鼠标悬浮会放大)基于jQuery+CSS3模拟印钞出钞动画效果CSS3的动画泡沫按钮效果基于CSS3技术的生成动画效果 Loading加载效果的各种小图片你正在寻找的CSS3 动画技术 css3气泡 css3关键帧动画创建的动态通知气泡如何使用html5与css3完成google涂鸦动画
- css3的transform中scale缩放详解css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- 详谈IE条件注释面向XHTML的IE条件注释IE的有条件注释优点和缺点css 条件注释区分非IE浏览器 针对主流浏览器的CSS-HACK写法及IE常用条件注释 ie10 css hack 条件注释等兼容方式整理浏览器兼容之旅第一站:如何在页面中创建IE条件注释条件注释判断浏览器(ie系列)使用条件注释判断 IE 浏览器版本适用于IE5.0及以上版本
- css3实例教程 一款纯css3实现的发光屏幕旋转特效css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- css3的transform造成z-index无效解决方案div层调整z-index属性在IE中无效原因分析及解决方法ActiveX插件的Z-Index属性无效问题解决IE6 select z-index无效,遮挡div bug的解决方法div层调整z-index属性无效原因分析及解决方法
- 浅谈CSS伪类与伪元素详解如何使用CSS3中的结构伪类选择器和伪元素选择器解析CSS中的伪元素及其与伪类的区别详解CSS中的伪类与伪元素及二者间的区别CSS伪类和伪元素的区别详解css3 伪元素和伪类选择器详解CSS伪类/伪元素选择器整理css伪类伪元素域高级选择器的介绍CSS伪类与CSS伪元素的区别及由来具体说明浅谈CSS 伪元素&伪类的妙用