我正在尝试查找字符串中每次出现的字符串,并将其替换为
<span class="blue_color_text">matched_string</span>
这就是我正在使用的(在其中一个问题中找到它):
String.prototype.replaceAll = function(search, replacement) {
var target = this;
return target.replace(new RegExp(search, 'g'), replacement);
};
这是实际的实施:
function showResult(str)
{
if (str.length == 0)
{
return;
}
if (window.XMLHttpRequest)
{
xmlhttp = new XMLHttpRequest();
}
xmlhttp.onreadystatechange = function() {
var e = document.getElementById("res_ls");
if (xmlhttp.readyState == 4 && xmlhttp.status == 200)
{
xmlhttp.responseText.replaceAll(search_string.value, "<span class=\"green\">"+search_string.value+"</span>");
e.innerHTML = xmlhttp.responseText;
e.removeAttribute("class");
}
}
xmlhttp.open("GET","ajax.php?s="+str, true);
xmlhttp.send();
}
String.prototype.replaceAll = function(search, replacement) {
var target = this;
return target.replace(new RegExp(search, 'g'), replacement);
};
实际上没有任何改变。知道为什么吗?
答案 0 :(得分:4)
.replaceAll()
返回修改后的字符串的新实例,它不会更改现有的字符串引用。因此,如果要引用修改后的字符串,则需要存储.replaceAll()
你需要使用
e.innerHTML = xmlhttp.responseText.replaceAll(search_string.value, "<span class=\"green\">"+search_string.value+"</span>");
答案 1 :(得分:0)
JavaScript中的字符串是不可变的,因此replaceAll
不会更改字符串本身,而是返回一个新字符串:
String.prototype.replaceAll = function(search, replacement) {
var target = this;
return target.replace(new RegExp(search, 'g'), replacement); // <--- HERE
};
您需要将replaceAll的返回值分配给原始字符串:
xmlhttp.responseText = xmlhttp.responseText.replaceAll(search_string.value, "<span class=\"green\">"+search_string.value+"</span>");
答案 2 :(得分:0)
尝试使用J-Query:
$('
//Code to find strings
').replaceWith('<span class="blue_color_text">matched_string</span>');