ACE编辑器 - 美化CSS

时间:2016-06-15 09:45:11

标签: javascript ace-editor

我目前正在实现ace作为几种编程语言的编辑器。我真的想实现美化功能,目前我使用这种方法:

var beautify = ace.require("ace/ext/beautify"); // get reference to extension
var editor = ace.edit("editor"); // get reference to editor
beautify.beautify(editor.session);

More info

遗憾的是,这并没有正确格式化CSS。示例:

.class1 .subClass { color: red; }

通过描述的代码美化,这变为

.class1.subClass{
    color:red;
}

您可以看到选择器中的所有空格都被删除,这会更改规则的目标。

我的代码错了吗?在ace中有没有替代美化CSS?

作为后备,我会删除不是理想解决方案的功能。

TL; DR

是否有ace的插件/扩展可以正确美化CSS?难道我做错了什么?

1 个答案:

答案 0 :(得分:0)

我找到了一个很好的css beautifier,我加入了我的解决方案。

这就是魔术:

container.querySelector('.editor_beautify').addEventListener('click', function () {
    var currentMode = editor.session.$modeId.substr(editor.session.$modeId.lastIndexOf('/') + 1);
    switch (currentMode) {
        case modes.css:
            util.formatCss(editor, configuration.scriptBase);
            break;
        default:
            util.ensureScript(configuration.scriptBase + 'ext-beautify.js', function () {
                var beautify = ace.require("ace/ext/beautify").beautify(editor.session);
            });
    }
});
formatCss: function (editorAce, scriptBase) {
    var unformatted = editorAce.getValue();
    if (unformatted.trim().length > 0) {
        util.ensureScript(scriptBase + 'cssbeautify.js', function () {
            editorAce.getSession().setUseWrapMode(false);
            var formatted = cssbeautify(unformatted, {
                indent: '  ',
                openbrace: 'end-of-line',
                autosemicolon: true
            });

            editorAce.setValue(formatted);
            editorAce.getSession().setUseWrapMode(true);
        });                
    }
}