如何在codemirror

时间:2016-07-21 05:58:18

标签: javascript codemirror ui-codemirror

我在我的应用程序中使用codemirror API,我试图显示总行数以及何时计算新行数但是它给了我另一件事

我使用这个脚本来获取数字的最后一个孩子,但是当我有29行它显示 1234567891011121314151617181920212223242526272829 这不是我打算做的,我希望它只显示 29 并且onkeydown根本不起作用

  <script>
    $(document).ready(function(){
      var tolalline = $('.CodeMirror-linenumber:last-child').text();
      $('#hcunter').text(tolalline);
      $('#inputTextToSave').keydown(function(){
        var tolalline = $('.CodeMirror-linenumber:last-child').text();
        $('#hcunter').text(tolalline);
      }
                                  );
      $("#alterTool").click(function(){
        $("#EditTool").toggle(1000);
      });
    });
  </script>

CodeMirror

<script>
    var editor = CodeMirror.fromTextArea(document.getElementById("inputTextToSave"), 
    {
        lineNumbers: true,
        viewportMargin: Infinity,
        //Theme
        styleActiveLine: true,
        matchBrackets: true,
        gutter: true
    });
</script>

1 个答案:

答案 0 :(得分:0)

要获得行数,必须使用css选择器:

.CodeMirror-code > div:last-child div.CodeMirror-gutter-elt

因此,如果要计算行数,则将覆盖CodeMirror配置的extraKeys属性中的Enter键。它将是:

  extraKeys:
  {
    Enter: function(){
      setTimeout(function() {
        var tolalline = $('.CodeMirror-code > div:last-child div.CodeMirror-gutter-elt').text();
        $('#hcunter').text(tolalline);
      }, 0);
      return CodeMirror.Pass;
    }
  }

我设置了一个setTimeout来创建一个必要的最小延迟。您现在不需要设置onKeyDown事件。

所有代码:

  var editor = CodeMirror.fromTextArea(document.getElementById("inputTextToSave"),
      {
        lineNumbers: true,
        viewportMargin: Infinity,
        //Theme
        styleActiveLine: true,
        matchBrackets: true,
        gutter: true,
        extraKeys:
        {
          Enter: function(){
            setTimeout(function() {
              var tolalline = $('.CodeMirror-code > div:last-child div.CodeMirror-gutter-elt').text();
              $('#hcunter').text(tolalline);
            }, 0);
            return CodeMirror.Pass;
          }
        }
      }
    );


$(document).ready(function(){
  var tolalline = $('.CodeMirror-code > div:last-child div.CodeMirror-gutter-elt').text();
  $('#hcunter').text(tolalline);
  $("#alterTool").click(function(){
    $("#EditTool").toggle(1000);
  });
});

我希望你想要它! : - )