0

我已经通过 CodeRay 突出显示了 ruby​​ 代码,现在我想知道用户点击了哪个行号。此行号应与源代码中的 line nuber 对应。最好的方法是什么?

4

1 回答 1

0

这是我解决这个问题的方法。我用 CodeRay 的数字生成了 html。但是 CodeRay 在官方网站上没有准确的文档,所以在查看了 CodeRay 的代码后,我把它变成了这样:

content = CodeRay.scan(file.read, :ruby).div(:css => :class, 
                                                 :line_numbers => :inline)

:line_numbers => :table在我应该使用模式的情况下,该模式无法正常工作:inline。如果您不喜欢 html 页面中的数字,我认为您可以通过 css 或 javascript 将其删除。然后我写了一个小的javascript函数:

$('span').not('.no').click(function(e) {
    var target = $(e.target);
    target.effect('highlight', {}, 'slow');
    var i = 0;
    var prev_element = target.prev();
    var element;
    while (i++ < 10) {
        element = $(prev_element[0]).context;
        if (element.className == "no") break;
        prev_element = prev_element.prev();
    }
    if (i > 9) {
        alert("Some problem with the finding number line");
    }
    else {
        var line_number;
        if (element.children.length > 0) line_number = element.children[0].innerHTML;
        else                             line_number = element.innerHTML;
        alert(line_number);
    }
    e.stopPropagation();
})

任何建议和改进将不胜感激。

于 2011-05-23T20:15:14.547 回答