【问题标题】:Programmatically selecting partial text in an input field以编程方式选择输入字段中的部分文本
【发布时间】:2010-10-13 09:28:44
【问题描述】:

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

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

【问题讨论】:

  • 你需要多解释一下你想要做什么。
  • 哦,你想选择单个字符。 ://

标签: javascript html html-input


【解决方案1】:

这里是选择文本框的一部分(范围选择)并获取所选文本的方法:

<!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>

Demo

【讨论】:

  • 这里有 2 个错误。 1. 您需要在调用setSelectionRange 之前聚焦,否则将不会选择任何内容。 2. 第三个 if 语句应该是 else if( typeof field.selectionStart != 'undefined' ) 因为 field.selectionStart 可以评估为 0 这是假的
【解决方案2】:

小修正。似乎 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();
} 

【讨论】:

    【解决方案3】:

    谢谢!我现在想分享我的功能,它在 Ajaxel CMS 中与 Instant messenger 一起使用

    ,wrapText:function(o, ot, ct) {
        var s = o[0].selectionStart; 
        var e = o[0].selectionEnd;
        o.val(o.val().substring(0, s)+ot+o.val().substring(s,e)+ct+o.val().substring(e, o.val().length)); 
        if (o[0].createTextRange){
            var sr = o[0].createTextRange(); 
            sr.collapse(true); 
            sr.moveStart('character', s); 
            sr.moveEnd('character',e-s+ot.length+ct.length); 
            sr.select();
        }
        else if(o[0].setSelectionRange){ 
            o[0].setSelectionRange(s,e+ot.length+ct.length); 
        }
        else if(o[0].selectionStart){ 
            o[0].selectionStart=s; 
            o[0].selectionEnd=e+ot.length+ct.length; 
        }
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-03-17
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-06-07
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多