Respostas:
$('b').contents().unwrap();
Isso seleciona todos os <b>
elementos e, em seguida, usa.contents()
para direcionar o conteúdo de texto do e <b>
, em seguida.unwrap()
, para remover seu <b>
elemento pai .
Para obter o melhor desempenho, sempre vá nativo:
var b = document.getElementsByTagName('b');
while(b.length) {
var parent = b[ 0 ].parentNode;
while( b[ 0 ].firstChild ) {
parent.insertBefore( b[ 0 ].firstChild, b[ 0 ] );
}
parent.removeChild( b[ 0 ] );
}
Isso será muito mais rápido do que qualquer solução jQuery fornecida aqui.
.replacewith()
a passagem extra do DOM ... se for uma <b>
tag apenas com HTML, fica ainda mais rápido.
parent.normalize()
depois parent.removeChild(...
para mesclar nós de texto adjacentes. Isso foi útil se você estiver modificando continuamente a página.
Você também pode usar .replaceWith()
, assim:
$("b").replaceWith(function() { return $(this).contents(); });
Ou se você sabe que é apenas uma string:
$("b").replaceWith(function() { return this.innerHTML; });
Isso pode fazer uma grande diferença se você estiver desembrulhando muitos elementos, pois qualquer uma das abordagens acima é significativamente mais rápida que o custo .unwrap()
.
A maneira mais simples de remover elementos html internos e retornar apenas texto seria a função JQuery .text () .
Exemplo:
var text = $('<p>A nice house was found in <b>Toronto</b></p>');
alert( text.html() );
//Outputs A nice house was found in <b>Toronto</b>
alert( text.text() );
////Outputs A nice house was found in Toronto
Que tal agora?
$("b").insertAdjacentHTML("afterend",$("b").innerHTML);
$("b").parentNode.removeChild($("b"));
A primeira linha copia o conteúdo HTML da b
marca para o local diretamente após a b
marca e, em seguida, a segunda linha remove ob
marca do DOM, deixando apenas seu conteúdo copiado.
Normalmente, envolvo isso em uma função para facilitar o uso:
function removeElementTags(element) {
element.insertAdjacentHTML("afterend",element.innerHTML);
element.parentNode.removeChild(element);
}
Todo o código é realmente Javascript puro, o único JQuery usado é o de selecionar o elemento a ser segmentado (o b
tag no primeiro exemplo). A função é apenas JS: D
Veja também:
// For MSIE:
el.removeNode(false);
// Old js, w/o loops, using DocumentFragment:
function replaceWithContents (el) {
if (el.parentElement) {
if (el.childNodes.length) {
var range = document.createRange();
range.selectNodeContents(el);
el.parentNode.replaceChild(range.extractContents(), el);
} else {
el.parentNode.removeChild(el);
}
}
}
// Modern es:
const replaceWithContents = (el) => {
el.replaceWith(...el.childNodes);
};
// or just:
el.replaceWith(...el.childNodes);
// Today (2018) destructuring assignment works a little slower
// Modern es, using DocumentFragment.
// It may be faster than using ...rest
const replaceWithContents = (el) => {
if (el.parentElement) {
if (el.childNodes.length) {
const range = document.createRange();
range.selectNodeContents(el);
el.replaceWith(range.extractContents());
} else {
el.remove();
}
}
};
Outra solução nativa (no café):
el = document.getElementsByTagName 'b'
docFrag = document.createDocumentFragment()
docFrag.appendChild el.firstChild while el.childNodes.length
el.parentNode.replaceChild docFrag, el
Não sei se é mais rápido que a solução do user113716, mas pode ser mais fácil entender para alguns.
A resposta mais simples é alucinante:
Aqui está para fazê-lo com javascript, mesmo sem jQuery
function unwrap(selector) {
var nodelist = document.querySelectorAll(selector);
Array.prototype.forEach.call(nodelist, function(item,i){
item.outerHTML = item.innerHTML; // or item.innerText if you want to remove all inner html tags
})
}
unwrap('b')
Isso deve funcionar em todos os principais navegadores, incluindo o IE antigo. no navegador recente, podemos até chamar cada um diretamente no nodelist.
function unwrap(selector) {
document.querySelectorAll('b').forEach( (item,i) => {
item.outerHTML = item.innerText;
} )
}
unwrap()
e não conseguia me lembrar de como obter a parte do texto, esqueci.contents()
- excelente.