以编程方式在输入字段中选择部分文本

Ton*_*ony 42 html javascript html-input

如何以编程方式在HTML input字段中选择特定范围的文本?(我不想选择整个字段,只是一个子集)

另外,如何确定字段中当前选定的范围?

Dar*_*rov 56

以下是如何选择文本框的一部分(范围选择)并获取所选文本:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title> Test </title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script type="text/javascript">
  window.onload = function() {
    var message = document.getElementById('message');
    // Select a portion of text
    createSelection(message, 0, 5);
    // get the selected portion of text
    var selectedText = message.value.substring(message.selectionStart, message.selectionEnd);
    alert(selectedText);
  };

  function createSelection(field, start, end) {
    if( field.createTextRange ) {
      var selRange = field.createTextRange();
      selRange.collapse(true);
      selRange.moveStart('character', start);
      selRange.moveEnd('character', end);
      selRange.select();
      field.focus();
    } else if( field.setSelectionRange ) {
      field.focus();
      field.setSelectionRange(start, end);
    } else if( typeof field.selectionStart != 'undefined' ) {
      field.selectionStart = start;
      field.selectionEnd = end;
      field.focus();
    }
  }
</script>
</head>
<body>
<input type="text" name="message" id="message" value="Hello World" />
</body>
</html>
Run Code Online (Sandbox Code Playgroud)

演示

  • **这里有2个错误.**1.你需要在**调用`setSelectionRange`之前关注**或者什么都不会被选中.2.第3个if语句应该是`else if(typeof field.selectionStart!='undefined')`因为`field.selectionStart`可以计算为0,这是假的 (4认同)

小智 13

小修正.似乎IE moveEnd()方法逐步移动所以selRange.moveEnd('character', end) 应该替换为selRange.moveEnd('character', end-start):

function createSelection(field, start, end) {
    if( field.createTextRange ) {
        var selRange = field.createTextRange();
        selRange.collapse(true);
        selRange.moveStart('character', start);
        selRange.moveEnd('character', end-start);
        selRange.select();
    } else if( field.setSelectionRange ) {
        field.setSelectionRange(start, end);
    } else if( field.selectionStart ) {
        field.selectionStart = start;
        field.selectionEnd = end;
    }
    field.focus();
} 
Run Code Online (Sandbox Code Playgroud)