【问题标题】:Convert Sass String (not SCSS) to CSS String将 Sass 字符串(不是 SCSS)转换为 CSS 字符串
【发布时间】:2016-08-21 12:18:52
【问题描述】:


我需要将 SASSSCSS 字符串编译为项目的 CSS 字符串。因此,我使用的是节点包 node-sass。转换 SCSS 可以正常工作,但 SASS 不能。

SASS 的示例代码:

'use strict';

var sass = require('node-sass');

var dataTemp = 'body{background:blue; a{color:black;}}';

var output = sass.renderSync({
  data: dataTemp
});

console.log(output.css.toString());

问题来了,当我尝试转换这样的东西时,它应该是有效的 .sass 语法

'use strict';

var sass = require('node-sass');

var dataTemp = '.red\n color: red';

var output = sass.renderSync({
  data: dataTemp
});

console.log(output.css.toString());

控制台输出:

Error: Invalid CSS after ".": expected 1 selector or at-rule, was ".red color: red "

显然 node-sass 不能以这种方式编译 .sass 代码。 node-sass 的语法是:

var result = sass.renderSync({
  data: scss_content
  [, options..]
});

在对象内部,您可以定义选项甚至函数。也许有办法在这样的函数中编译数据?

对于其他软件包有任何其他解决方案或建议吗?

【问题讨论】:

  • 你还没有告诉我们为什么这不起作用?你在outpu.css中也有错字
  • 感谢您的反馈! :)

标签: css node.js sass node-sass


【解决方案1】:

通过添加一个名为“indentedSyntax”的选项并将其设置为“true”,node-sass 也可以编译 .sass 代码。抱歉,应该更准确地阅读文档。感谢您的帮助!

'use strict';

var sass = require('node-sass');

var dataTemp = '.red\n color: red';

var output = sass.renderSync({
  data: dataTemp,
  indentedSyntax: true,
  outputStyle : 'compressed'
});

console.log(output.css.toString());

日志:“.red{color:red}”

【讨论】:

    【解决方案2】:

    您的 SCSS 无效 - 您需要在属性周围提供 {}

    'use strict';
    
    var sass = require('node-sass');
    
    var dataTemp = '.red {color: red}';
    
    var output = sass.renderSync({
      data: dataTemp
    });
    
    console.log(output.css.toString());
    

    您可以使用SassMeister等在线工具验证您的 SASS/SCSS

    【讨论】:

    • 对,正常的 SCSS 语法可以正常工作,但我也需要的 SASS 语法不能。那里有错字,但 '.red\n color: red' 应该是有效的 .sass 语法。
    • 我不确定这是否正确。请参阅上面对我的帖子的更新 - 使用验证器,您的原始值无效,但我建议的值是有效的。
    • 不幸的是,我对 SASS/SCSS 不太熟悉,但我认为我需要 link 中描述的语法,您可以在其中切换 SCSS 和 SASS 语法。因此我想,“.red\n color: red”应该是有效的?
    猜你喜欢
    • 2014-01-23
    • 1970-01-01
    • 2015-09-16
    • 2019-10-10
    • 2019-01-05
    • 2020-11-28
    • 2021-04-21
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多