以编程方式选择输入字段中的部分文本
Posted
技术标签:
【中文标题】以编程方式选择输入字段中的部分文本【英文标题】:Programmatically selecting partial text in an input field 【发布时间】:2010-10-13 09:28:44 【问题描述】:如何以编程方式在 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;
【讨论】:
以上是关于以编程方式选择输入字段中的部分文本的主要内容,如果未能解决你的问题,请参考以下文章
以编程方式创建 VC,使用公式中文本字段中的整数并在点击 UIButton 时执行计算
Sencha Touch:如何以编程方式关注 ios 上的文本字段?