CodeMirror 使用多个提示源进行自动完成

CodeMirror Use multiple hint sources for autocomplete

本文关键字:提示 CodeMirror      更新时间:2023-09-26

是否可以包含多个提示源以进行自动完成?我试过这个:

CodeMirror.commands.autocomplete = function(cm) {
    CodeMirror.showHint(cm, CodeMirror.hint.xml);
    CodeMirror.showHint(cm, CodeMirror.hint.html);
    CodeMirror.showHint(cm, CodeMirror.hint.css);
    CodeMirror.showHint(cm, CodeMirror.hint.javascript);
};

但它似乎只包含引用的最后一个源文件,而忽略其余文件。有没有简单的方法可以做到这一点?

我在另一个问题中找到了问题的答案,所以如果这让这个问题有点多余,请原谅我。我需要做的是找出在调用自动完成时当前处于活动状态的模式(我使用的是混合模式)。首先,我需要模式:

var mode = CodeMirror.innerMode(cm.getMode(), cm.getTokenAt(POS).state).mode.name;

我在这里找到的。对于我的情况,我想在调用自动完成时执行此操作,因此我的函数如下所示:

CodeMirror.commands.autocomplete = function(cm) {
    var doc = cm.getDoc();
    var POS = doc.getCursor();
    var mode = CodeMirror.innerMode(cm.getMode(), cm.getTokenAt(POS).state).mode.name;
    if (mode == 'xml') { //html depends on xml
        CodeMirror.showHint(cm, CodeMirror.hint.html);
    } else if (mode == 'javascript') {
        CodeMirror.showHint(cm, CodeMirror.hint.javascript);
    } else if (mode == 'css') {
        CodeMirror.showHint(cm, CodeMirror.hint.css);
    }
};

现在,每当调用自动完成功能时,它都会检查编辑器在文档中特定点所处的模式。

处理此问题的功能已经存在于(最新版本的)CodeMirror中,您可以在其中使用 defineHelper 定义特定于语言的帮助程序函数,如果您不给它显式完成函数,标准完成器(show-hint.js)将使用为该语言定义的函数。标准完成器插件确实将自己注册为适用于他们的语言,因此它应该"开箱即用"地工作。