我有一个div <div id="masterdiv">,它有几个子<div>s。

例子:

<div id="masterdiv">
  <div id="childdiv1" />
  <div id="childdiv2" />
  <div id="childdiv3" />
</div>

如何使用jQuery清除所有子<div>的内容里面的主<div> ?


当前回答

使用jQuery的CSS选择器语法选择id为masterdiv的元素中的所有div元素。然后调用empty()来清除内容。

$('#masterdiv div').empty();

使用text(")或html(")将导致进行一些字符串解析,在使用DOM时,这通常是一个坏主意。尽可能尝试使用不涉及DOM对象的字符串表示的DOM操作方法。

其他回答

jQuery的empty()函数就是这样做的:

$('#masterdiv').empty();

清除主div。

$('#masterdiv div').empty();

清除所有子div,但保留主div完整。

$("#masterdiv > *").text("")

or

$("#masterdiv").children().text("")

jQuery建议你使用".empty()",".remove()",".detach()"

如果你需要删除元素中的所有元素,使用下面的代码:

$('#target_id').empty();

如果你需要删除所有元素,使用以下代码:

$('#target_id').remove();

i和jQuery小组不建议使用SET函数像.html() .attr() .text(),这是什么?如果你想设置任何你需要的东西

裁判:https://learn.jquery.com/using-jquery-core/manipulating-elements/

如果masterdiv中的所有div都需要被清除,它是这样的。

$('#masterdiv div').html('');

否则,您需要迭代#masterdiv的所有子div,并检查id是否以childdiv开头。

$('#masterdiv div').each(
    function(element){
        if(element.attr('id').substr(0, 8) == "childdiv")
        {
            element.html('');
        }
    }
 );

如果有用的话,试试吧。

$('。div_parent .div_child”)空虚();

$ (' # div_parent # div_child ')空虚();