当前位置: 首页 > 面试题库 >

使用PHP自动将引用的LESS文件编译为CSS

袁卓
2023-03-14
问题内容

我希望发生以下事情:

  1. 具有流程自动化服务器端。

  2. 就像我的代码中的CSS文件一样,仅能够引用LESS文件。

  3. 返回给用户的是缩小的CSS而不是LESS文件-已缓存,因此除非LESS文件已更新,否则编译器无需运行。

  4. 为了使其与我域中任何地方引用的 所有 LESS文件一起使用。

我发现了Lessphp,但是文档不是很清楚,也没有说明如何动态地向其中获取任何LESS文件。我以为我会发布如何使所有功能正常工作,因为我还没有看到如何用PHP实现这一目标的过程。


问题答案:

该组件LESSPHP v0.3.8 + 不确定较早的版本,但是如果不立即使用它,您将了解其工作原理。

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

如果您使用less.js来编译客户端,请确保更改rel="stylesheet/less"rel="stylesheet"

1)GrabLessphp我将这些文件放在/www/compilers/lessphp/此演示的上下文中

2)创建一个PHP脚本,我们可以将其丢弃。这将处理缓存,编译为CSS并返回CSS作为响应。我已经把这个文件的/www/compilers/,并把它称为lessphp.php

这段代码大部分都在Lessphp网站上,除了其中有错误之外,我在最后添加了响应。

<?php
require "lessphp/lessc.inc.php";
$file = $_GET["file"];
function autoCompileLess($inputFile, $outputFile) {
    // load the cache
    $cacheFile = $inputFile.".cache";
    if (file_exists($cacheFile)) {
        $cache = unserialize(file_get_contents($cacheFile));
    } else {
        $cache = $inputFile;
    }
    $less = new lessc;
    $less->setFormatter("compressed");
    $newCache = $less->cachedCompile($cache);
    if (!is_array($cache) || $newCache["updated"] > $cache["updated"]) {
        file_put_contents($cacheFile, serialize($newCache));
        file_put_contents($outputFile, $newCache['compiled']);
    }
}
autoCompileLess('../' . $file, '../' . $file . '.css');
header('Content-type: text/css');
readfile('../' . $file . '.css');
?>

这会将LESS文件(例如,styles/main.less)编译为缓存文件和CSS文件(例如,styles/main.less.css)。

3)添加一条mod_rewrite规则,以便将用户请求的所有LESS文件重定向到我们的编译器,并为其指定路径。这被放置在根.htaccess文件中。

<IfModule mod_rewrite.c>
    RewriteEngine On
    RewriteBase /
    RewriteRule ^([^.]*\.less)$ compilers/lessphp.php?file=$1 [R,QSA,L]
</ifModule>

如果您使用的是WordPress,则需要遵循此规则-即使WordPress位于子目录中,它似乎也会覆盖这些规则,并且对于(在目录方面)WordPress.htaccess规则下的引用文件,不会进行LESS编译。

4)您的LESS代码应相对于编译器位置进行相对引用。另外,如果有空属性,例如,Lessphp编译器将失败。background-color: ;

如果一切正常,则应进行以下操作:

  1. 直接浏览您的LESS文件 http://domain.com/styles/main.less

  2. 自动重定向http://domain.com/compilers/lessphp?file=styles/main.less

  3. 呈现最小的CSS

  4. main.less.cssmain.less.cache现在应该在同一个目录中存在作为你的LESS文件

  5. 除非您更新LESS文件,否则上次修改日期不应更改



 类似资料:
  • 访问论坛获取帮助 请务必理解如下章节后阅读此章节: 安装 Node 和 gulp 使用 gulp 压缩 JS Less 是一门 CSS 预处理语言,它扩充了 CSS 语言,增加了诸如变量、混合(mixin)、函数等功能,让 CSS 更易维护。 安装 npm install gulp-less 基本用法 你可以 下载所有示例代码 - 或在线查看代码 // 获取 gulp var gulp = req

  • 问题内容: 我正在使用Grunt构建我的Web项目。我安装了软件包,并向我添加了一个任务 当我通过 更少 运行目标时,它运行没有错误,但没有将less文件编译为css文件。 我也通过node 安装了 lessc 软件包。做的很好。 目前,我已将 files选项 直接指向一个目录,该目录包含一个要测试的文件。即使我将整个文件名写入 files选项 ,也不会发生任何事情… 稍后,我想扫描整个js目录并

  • 我正在使用wro4j 1.7.3和less4j/lesscss-compiler。 在我的wro.xml中,我有如下内容: 在编译时,我会得到一个错误,因为wro4j将我的*.css-file也当作*.less-file来处理。 当使用lessCSS时,而不是less4j,错误原因更好地显示出来: 更改处理器顺序无济于事: 错误仍然存在。 是否存在这样的可能性,比如wro4j,它不应该将带有css

  • 给出了以下简单的项目结构。 内容是

  • 我正在玩基于Windows上的MoarVM构建的perl6版本。我创建了一些perl6文件并想将其编译为exe。我尝试了以下操作: 现在我想把r编译成可执行文件 我发现这个链接谈论如何使用鹦鹉,但我正在使用MoarVM目标:http://perlgeek.de/blog-en/perl-6/my-first-executable.writeback 我的问题如何将MoarvVM目标文件编译为Win

  • 我有一个原型文件,用协议2语法编写。我正在使用协议3编译器编译这个原型文件。虽然它成功构建,但它在运行时显示以下错误。有人能帮我吗? [libprotobuf FATAL google/protobuf/extension\u set.cc:102]x.y.z.a类型的多个扩展注册,字段号200。在抛出“google::protobuf::FatalException”what():type“x.