如何在textarea中选择文本行

Fla*_*Cat 9 javascript jquery textarea

我有一个textarea,用于存放大量的SQL脚本进行解析.当用户单击"Parse"按钮时,他们将获得有关SQL脚本的摘要信息.

我希望摘要信息是可点击的,这样当点击它时,SQL脚本的行在textarea中突出显示.

我已经在输出中有行号,所以我需要的是javascript或jquery,告诉它要突出显示哪个textarea行.

是否有某种类型的" goToLine "功能?在我所有的搜索中,没有什么能解决我正在寻找的问题.

los*_*rce 26

此函数要求第一个参数引用您的textarea,第二个参数作为行号

function selectTextareaLine(tarea,lineNum) {
    lineNum--; // array starts at 0
    var lines = tarea.value.split("\n");

    // calculate start/end
    var startPos = 0, endPos = tarea.value.length;
    for(var x = 0; x < lines.length; x++) {
        if(x == lineNum) {
            break;
        }
        startPos += (lines[x].length+1);

    }

    var endPos = lines[lineNum].length+startPos;

    // do selection
    // Chrome / Firefox

    if(typeof(tarea.selectionStart) != "undefined") {
        tarea.focus();
        tarea.selectionStart = startPos;
        tarea.selectionEnd = endPos;
        return true;
    }

    // IE
    if (document.selection && document.selection.createRange) {
        tarea.focus();
        tarea.select();
        var range = document.selection.createRange();
        range.collapse(true);
        range.moveEnd("character", endPos);
        range.moveStart("character", startPos);
        range.select();
        return true;
    }

    return false;
}
Run Code Online (Sandbox Code Playgroud)

用法:

 var tarea = document.getElementById('myTextarea');
 selectTextareaLine(tarea,3); // selects line 3
Run Code Online (Sandbox Code Playgroud)

工作范例:

http://jsfiddle.net/5enfp/