我正在尝试执行一个简单的搜索和突出显示功能Javascript
来搜索一段文本。出现该段文本的XHTML
标记也作为参数给出,以在定位该文本时提供额外帮助。
我正在测试此功能的 XHTML:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta content="application/xml+xhtml;charset=UTF-8" />
<script src="searcher.js" type="text/javascript"></script>
<script src="jquery-2.0.2.min.js"> </script>
<title>Building your resume</title>
</head>
<body id="highlightbegin">
<h1>Building your resume</h1>
<div> <input name="input" type="button" value="Highlight3" onclick="javascript:searcher('<h1>','Building your resume', '<h1>Building your resume', 'resume');" /> </div>
</body>
</html>
searcher.js 中的函数 searcher:
function searcher(tag, text, tagText, word) {
//simple search.
console.info(word + " to be searched for in " + text + " with tag text = " + tagText);
//get old html.
var oldHTML = document.getElementById("highlightbegin").innerHTML;
//get regexp.
var regexp = new RegExp(tagText, 'g');
var match = oldHTML.match(regexp);
console.info(text + " found " + match.length + " times.");
}
但是,执行RegExp
, match 会返回null
。进一步的调查显示,标签<h1>Building your resume</h1>
成为<h1 xmlns="http://www.w3.org/1999/xhtml">Building your resume</h1>
导致match
函数返回的原因null
。我的问题:
- 为什么会
xmlns
自动添加属性? - 有没有办法防止属性被添加?
- 该属性将添加到哪些标签?假设它将被添加到每个标签中是否安全?
- 这是特定于浏览器的问题,还是在所有浏览器中都可以预期这种行为?
编辑:
观察:
1. 如果我将xmlns
属性添加到body
标签并使用outerHTML
( var oldHTML = document.getElementById("highlightbegin").outerHTML;
) 访问所有内容,则其子元素没有该xmlns
属性。
我的问题:
1. outerHTML 元素可以编辑(用Javascript
)和替换吗?
2.上面的观察是一致的(每次outerHTML
调用都看到)还是依赖于实现?
3. 是自动Javascript
添加xmlns
属性还是浏览器添加?