浏览器端Less

简介: 浏览器端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样式表。如下:


<link rel="stylesheet/less" type="text/css" href="styles.less" />


在渲染HTML页面时,less文件需要编译成css文件。我们可以有很多种方法。在服务器端,如Node.js,我们有专门的less编译模块。如果是在客户端,需要从LESS官网下载less.js文件,然后在HTML页面中引入,如下:


<script src="less.js" type="text/javascript"></script>


有了less编译工具,我们就可以渲染页面了。

  

在浏览器中使用less.js开发是很好的,但不推荐用于生产环境中。浏览器端使用是在使用LESS开发时最直观的一种方式。如果是在生产环境中,尤其是对性能要求比较高的场合,建议使用node或者其它第三方工具先编译成CSS再上线使用。


注意:


  • 确保包涵.less样式表在less.js脚本之前
  • 当你引入多个.less样式表时,它们都是独立编译的。所以,在每个文件中定义的变量、混合、命名空间都不会被其它的文件共享。
  • 必须通过服务器环境访问页面,否则报错


浏览器选项:


  

你可以引入<script src="less.js"></script>之前通过创建一个全局less对象的方式来指定参数,例如:


<!-- set options before less.js script -->
    <script>
      less = {
          env: "development",
          logLevel: 2,
          async: false,
          fileAsync: false,
          poll: 1000,
          functions: {},
          dumpLineNumbers: "comments",
          relativeUrls: false,
          globalVars: {
            var1: '"string value"',
            var2: 'regular value'
          },
          rootpath: ":/a.com/"
        };
    </script>
    <script src="less.js"></script>


但是这影响所有初始链接标记。你也可以在指定的脚本标签的增加选项,如下:


<script src="less.js" data-env="development"></script>

 

或者,你也可以在链接配置参数覆盖某些选项,如下:


<link data-dump-line-numbers="all" data-global-vars='{ myvar: "#ddffee", mystr: "\"quoted\"" }' rel="stylesheet/less" type="text/css" href="less/styles.less">


注意:


  • 以上三种配置参数的优先级为:link标签的>script标签>全局对象
  • 对象属性名称不驼峰
  • link标签的配置只和时间选项有关,其他不起作用


观察模式:


  

如果使用观察模式,则配置参数的env为development。然后在Less.js文件加载之后调用less.watch(),如下:


<script>less = { env: 'development'};</script>

<script src="less.js"></script>

<script>less.watch();</script>


注意:

  

如果启动了观察模式,则浏览器会不断请求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


<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
    <link rel="stylesheet/less" type="text/css" href="./less/reset.less" />
    <link rel="stylesheet/less" type="text/css" href="./less/styles.less" />
    <script src="./js/config.js"></script>
    <script src="./js/less-1.3.3.min.js"></script>
    <script>less.watch();</script>
</head>
<body>
</body>
</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,那么运行之前缓存将被清除。

 

相关文章
|
IDE Java 编译器
使用Java分割PDF文件
使用Java分割PDF文件
427 1
|
8月前
|
存储 前端开发 小程序
《Discuz! X3.5开发从入门到生态共建》系列教程大纲优雅草卓伊凡
《Discuz! X3.5开发从入门到生态共建》系列教程大纲优雅草卓伊凡
227 7
《Discuz! X3.5开发从入门到生态共建》系列教程大纲优雅草卓伊凡
|
安全 API 网络架构
Python中哪个框架最适合做API?
本文介绍了Python生态系统中几个流行的API框架,包括Flask、FastAPI、Django Rest Framework(DRF)、Falcon和Tornado。每个框架都有其独特的优势和适用场景。Flask轻量灵活,适合小型项目;FastAPI高性能且自动生成文档,适合需要高吞吐量的API;DRF功能强大,适合复杂应用;Falcon高性能低延迟,适合快速API开发;Tornado异步非阻塞,适合高并发场景。文章通过示例代码和优缺点分析,帮助开发者根据项目需求选择合适的框架。
2636 0
Error:java: 错误: 无效的源发行版:13, 类文件具有错误的版本 61.0, 应为 55.0 请删除该文件或确保该文件位于正确的类路径子目录中。
Error:java: 错误: 无效的源发行版:13, 类文件具有错误的版本 61.0, 应为 55.0 请删除该文件或确保该文件位于正确的类路径子目录中。
|
存储 人工智能 算法
【408数据结构与算法】—单链表的基本操作(六)
【408数据结构与算法】—单链表的基本操作(六)
|
机器学习/深度学习 人工智能 自然语言处理
《花雕学AI》21:脑筋急转弯---ChatGPT能够灵活运用逻辑推理和创造性思维吗?
随着人工智能技术的不断发展和成熟,ChatGPT在未来还有很大的应用前景。例如,在教育领域,ChatGPT可以被应用于编写智力游戏、脑力训练等课程内容,从而帮助学生提高思维能力和语言表达能力。同时,在娱乐行业,ChatGPT也可以被用于开发各种趣味游戏,满足人们的娱乐需求。 然而,我们也必须承认,ChatGPT在解决脑筋急转弯问题上仍存在一些挑战和限制。例如,在处理一些复杂的双关语和玩味语言时,模型的效果可能会受到影响,需要不断地优化和改进。
777 0
《花雕学AI》21:脑筋急转弯---ChatGPT能够灵活运用逻辑推理和创造性思维吗?
|
安全 数据安全/隐私保护
CAS与OAuth2的区别
CAS与OAuth2的区别 CAS的单点登录时保障客户端的用户资源的安全 。 OAuth2则是保障服务端的用户资源的安全 。 CAS客户端要获取的最终信息是,这个用户到底有没有权限访问我(CAS客户端)的资源。
7775 0
|
SQL Java Android开发
java.sql.SQLException: ORA-00604: error occurred at recursive SQL level 1
java.sql.SQLException: ORA-00604: error occurred at recursive SQL level 1 ORA-12705: Cannot access NLS data files or invalid environment specified方法一:跟换驱动jar包:http://hkme.
1450 0
|
7天前
|
JSON API 数据格式
OpenCode入门使用教程
本教程介绍如何通过安装OpenCode并配置Canopy Wave API来使用开源模型。首先全局安装OpenCode,然后设置API密钥并创建配置文件,最后在控制台中连接模型并开始交互。
3178 7