我想给一个字符串子串,比如follow。我有字符串的起始位置和长度。我已经检查了这个问题Substring text with HTML tags in Javascript。但是在这个子字符串中从 0 开始执行,但我有一个随机的起始位置。关于它将如何完成的任何想法
var str = 'Lorem ipsum <p>dolor <strong>sit</strong> amet</p>, consectetur adipiscing elit.'
我想给一个字符串子串,比如follow。我有字符串的起始位置和长度。我已经检查了这个问题Substring text with HTML tags in Javascript。但是在这个子字符串中从 0 开始执行,但我有一个随机的起始位置。关于它将如何完成的任何想法
var str = 'Lorem ipsum <p>dolor <strong>sit</strong> amet</p>, consectetur adipiscing elit.'
这是演示
function html_substr( str, start ,count ) {
var div = document.createElement('div');
div.innerHTML = str;
walk( div, track );
function track( el ) {
if( count > 0 ) {
var len = el.data.length;
if(start<=len){
el.data = el.substringData(start,len);
start=0;
} else{
start-=len;
el.data = '';
}
len = el.data.length;
count -= len;
if( count <= 0 ) {
el.data = el.substringData( 0, el.data.length + count );
}
} else {
el.data = '';
}
}
function walk( el, fn ) {
var node = el.firstChild;
do {
if( node.nodeType === 3 ) {
fn(node);
} else if( node.nodeType === 1 && node.childNodes && node.childNodes[0] ) {
walk( node, fn );
}
} while( node = node.nextSibling );
}
return div.innerHTML;
}
称它为
html_substr( str,13, 2 );
这是执行此类操作的本机 DOM API 方法。浏览器已经内置了强大的 HTML 解析能力。无需重新发明轮子
var el = document.createElement("div");
el.innerHTML = 'Lorem ipsum <p>dolor <strong>sit</strong> amet</p>, consectetur adipiscing elit.';
el.getElementsByTagName("p").textContent;
结果只是一个非 html 字符串,您可以轻松地使用它进行操作.substring
我们将 HTML 转储到 HTML 元素中。
然后我们使用 DOM API 说如下:
“在我们刚刚给你的 HTML 中,找到所有p
标签,取第一个(即 [0]),然后给我们它的 textContent”。