这在IE9中有效,但在Chrome中不起作用。
我想在Chrome中运行它。
这是当我在文本框中输入单词时要查找的单词。
谁能为我解决这个问题?
var n = 0;
var str = '';
function chk() {
str = form1.kts.value;
if (str == '') alert('none!');
else ok();
}
function ok() {
var found;
var text = document.body.createTextRange();
for (i = 0; i <= n && (found = text.findText(str)) != false; i++) {
text.moveStart("character", 1);
text.moveEnd("textedit");
}
if (found) {
text.moveStart("character", - 1);
text.findText(str);
text.scrollIntoView();
text.select();
n++;
} else {
if (n > 0) {
n = 0;
ok();
} else {
alert("nothing.");
form1.kts.value = '';
}
}
}
最佳答案
createTextRange
仅在IE(和某些版本的Opera)中受支持,要解决您的问题,您可能应该对其他浏览器使用createRange
。
var n = 0,
str = '';
function chk(){
str = form1.kts.value;
if(str == '') {
alert('none!');
}else{
ok();
}
}
function ok(){
var found, text;
if (document.createRange) {
text = document.body.createTextRange();
// do stuff for IE here
}else{
if( document.selectionStart ) {
text = document.setSelectionRange(start, end);
// do stuff for other browsers here
}
}
.........
关于javascript - createRange在Chrome中不起作用,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/12911793/