我为 libsass 选择了 node-sass 实现者,因为它基于 node.js。
安装 node-sass
- (先决条件)如果您没有 npm,请先安装Node.js。
$ npm install -g node-sass
全局安装 node-sass -g
。
如果没有在底部阅读 libsass,这将有望安装所有您需要的东西。
如何从命令行和 npm 脚本中使用 node-sass
一般格式:
$ node-sass [options] <input.scss> [output.css]
$ cat <input.scss> | node-sass > output.css
例子:
$ node-sass my-styles.scss my-styles.css
手动编译单个文件。
$ node-sass my-sass-folder/ -o my-css-folder/
手动编译文件夹中的所有文件。
$ node-sass -w sass/ -o css/
每当修改源文件时,都会自动编译文件夹中的所有文件。-w
添加对文件更改的监视。
更多有用的选项,例如“压缩” @ 这里。命令行非常适合快速解决方案,但是,您可以使用 Grunt.js 或 Gulp.js 等任务运行器来自动化构建过程。
您还可以将上述示例添加到 npm 脚本中。要正确使用 npm 脚本作为 gulp 的替代品,请阅读这篇综合性文章@css-tricks.com,尤其是阅读有关分组任务的内容。
package.json
如果您的项目目录中没有文件正在运行,$ npm init
则会创建一个。使用它-y
来跳过问题。
- 添加
"sass": "node-sass -w sass/ -o css/"
到文件scripts
中。package.json
它应该看起来像这样:
"scripts": {
"test" : "bla bla bla",
"sass": "node-sass -w sass/ -o css/"
}
如何与 gulp 一起使用
$ npm install -g gulp
全局安装 Gulp。
package.json
如果您的项目目录中没有文件正在运行,$ npm init
则会创建一个。使用它-y
来跳过问题。
$ npm install --save-dev gulp
在本地安装 Gulp。--save-dev
添加gulp
到. devDependencies
_package.json
$ npm install gulp-sass --save-dev
在本地安装 gulp-sass。
gulpfile.js
通过在项目根文件夹中创建一个包含以下内容的文件来为您的项目设置 gulp :
'use strict';
var gulp = require('gulp');
转换的基本示例
将此代码添加到您的 gulpfile.js:
var gulp = require('gulp');
var sass = require('gulp-sass');
gulp.task('sass', function () {
gulp.src('./sass/**/*.scss')
.pipe(sass().on('error', sass.logError))
.pipe(gulp.dest('./css'));
});
$ gulp sass
运行上述任务,编译文件夹中的 .scss 文件并在sass
文件夹中生成 .css 文件css
。
为了让生活更轻松,让我们添加一个手表,这样我们就不必手动编译它了。将此代码添加到您的gulpfile.js
:
gulp.task('sass:watch', function () {
gulp.watch('./sass/**/*.scss', ['sass']);
});
现在一切就绪!只需运行监视任务:
$ gulp sass:watch
如何与 Node.js 一起使用
正如 node-sass 的名称所暗示的那样,您可以编写自己的 node.js 脚本进行转译。如果您好奇,请查看 node-sass 项目页面。
libsass 呢?
Libsass 是一个需要由 sassC 等实现者构建的库,在我们的例子中是 node-sass。Node-sass 包含默认使用的 libsass 的构建版本。如果构建文件在您的机器上不起作用,它会尝试为您的机器构建 libsass。这个过程需要 Python 2.7.x(3.x 到今天还不能工作)。此外:
LibSass 需要 GCC 4.6+ 或 Clang/LLVM。如果您的操作系统较旧,则此版本可能无法编译。在 Windows 上,您需要使用 GCC 4.6+ 或 VS 2013 Update 4+ 的 MinGW。也可以在 Windows 上使用 Clang/LLVM 构建 LibSass。