32

我正在尝试使用 CodeMirror 设置代码示例的样式,但它可以部分工作 - 它将所选主题应用于textarea但语法未突出显示。

有我的页面:

<textarea id="template-html" name="code" class="CodeMirror">
    <!DOCTYPE html>
    <foobar>
        <blah>Enter your xml here and press the button below to display it as highlighted by the CodeMirror XML mode</blah>
        <tag2 foo="2" bar="bar" />
    </foobar>
</textarea>
<link rel="stylesheet" type="text/css" href="/site.com/css/codemirror/codemirror.css">
<link rel="stylesheet" type="text/css" href="/site.com/css/codemirror/theme/ambiance.css">
<link rel="stylesheet" type="text/css" href="/site.com/css/codemirror/theme/solarized.css">
<script type="text/javascript" src="/site.com/js/libs/codemirror/codemirror.js"></script>
<script type="text/javascript" src="/site.com/js/libs/codemirror/mode/javascript/javascript.js"></script>
<script type="text/javascript">
    var config, editor;

    config = {
        lineNumbers: true,
        mode: "text/html",
        theme: "ambiance",
        indentWithTabs: false,
        readOnly: true
    };

    editor = CodeMirror.fromTextArea(document.getElementById("template-html"), config);

    function selectTheme() {
        editor.setOption("theme", "solarized dark");
    }
    setTimeout(selectTheme, 5000);
</script>

这是结果的图像。它似乎有效,但没有语法突出显示(图像顶部),我也尝试过不使用我的 CSS,但结果是相同的(图像底部):

codemirror html模式

问题在于,如果我使用它通过 JavaScript 语法规则为标签着色mode: "text/html",它似乎无法正常工作。mode: "javascript"我怎样才能解决这个问题?

4

2 回答 2

66

CodeMirror 使用 XML 模式解析 HTML。要使用它,必须包含适当的脚本,与任何其他模式相同。

在你的标记中添加它的依赖:

<script type="text/javascript" 
        src="/site.com/js/libs/codemirror/mode/xml/xml.js"></script>

并将模式设置为xml

config = {
    mode : "xml",
    // ...
};

此外,您可能希望将解析器配置为允许格式不正确的 XML。htmlMode您可以通过打开标志来做到这一点:

config = {
    mode : "xml",
    htmlMode: true,
    // ...
};

有关实时示例,请参阅XML/HTML 模式演示

于 2013-07-13T18:20:24.890 回答
0

以防万一我的经验对某人有帮助。

我犯了以下错误

<script src="lib/codemirror.js"></script>
<script type="text/javascript">
    const editor = CodeMirror.fromTextArea(document.getElementById('textarea'), {
        mode: "css",
        lineNumbers: true,
        foldGutter: true,
        gutters: ["CodeMirror-linenumbers", "CodeMirror-foldgutter", "CodeMirror-lint-markers"],
        lint: true
    });
</script>
<script src="addons/lint/lint.js"></script>
<script src="addons/lint/css-lint.js"></script>
<script src="addons/fold/brace-fold.js"></script>
<script src="addons/fold/foldcode.js"></script>
<script src="addons/fold/foldgutter.js"></script>
<script src="addons/fold/indent-fold.js"></script>
<script src="addons/fold/markdown-fold.js"></script>
<script src="mode/css.js"></script>
<script src="//unpkg.com/csslint@1.0.5/dist/csslint.js"></script>

这是错误的:我首先调用了 codemirror.js - 主文件,然后初始化了编辑器,然后调用了它的资产。在这种情况下,它不起作用,我花了一些时间才找到问题(我是在 WordPress 中做的,所以我只是让我的脚本仅依赖于 codemirror.js)。

于 2020-04-27T12:52:02.083 回答