1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
---
title: Node.remove()
slug: orphaned/Web/API/ChildNode/remove
translation_of: Web/API/ChildNode/remove
original_slug: Web/API/ChildNode/remove
---
<p>Метод <code><strong>Node.remove()</strong></code> удаляет узел из дерева DOM</p>
<p> </p>
<p>То, что элемент удалён из DOM, ещё не значит, что он удалён совсем! </p>
<p>Он остался объектом и исчезнет только тогда, когда исчезнут все ссылки на него.</p>
<p> </p>
<h2 id="Синтаксис">Синтаксис</h2>
<pre><em>Node</em>.remove();
</pre>
<ul>
<li><strong><code>Node</code></strong> - любой узел DOM</li>
</ul>
<h2 id="Пример">Пример</h2>
<h3 id="Использование_remove()">Использование remove()</h3>
<pre><div id="box">
<div id="one"></div>
<div id="two"></div>
</div></pre>
<pre class="brush: js">var elem = document.querySelector("#one");
elem.remove();
alert(document.querySelector("#box").innerHTML); //Исчез блок #one
alert(elem); //Но как видите, сам объект ещё жив</pre>
<h2 id="Полифил">Полифил</h2>
<p>Можно создать полифил для IE 9 и выше, используя следующий код:</p>
<pre class="brush: js">(function() {
var arr = [window.Element, window.CharacterData, window.DocumentType];
var args = [];
arr.forEach(function (item) {
if (item) {
args.push(item.prototype);
}
});
// from:https://github.com/jserz/js_piece/blob/master/DOM/ChildNode/remove()/remove().md
(function (arr) {
arr.forEach(function (item) {
if (item.hasOwnProperty('remove')) {
return;
}
Object.defineProperty(item, 'remove', {
configurable: true,
enumerable: true,
writable: true,
value: function remove() {
this.parentNode.removeChild(this);
}
});
});
})(args);
})();</pre>
<h2 id="Спецификация">Спецификация</h2>
<table class="standard-table">
<tbody>
<tr>
<th scope="col">Спецификация</th>
<th scope="col">Статус</th>
<th scope="col">Комментарий</th>
</tr>
<tr>
<td>{{SpecName('DOM WHATWG', '#dom-childnode-remove', 'ChildNode.remove')}}</td>
<td>{{Spec2('DOM WHATWG')}}</td>
<td>Initial definition.</td>
</tr>
</tbody>
</table>
<h2 id="Поддержка_браузерами">Поддержка браузерами</h2>
<p>{{Compat("api.ChildNode.remove")}}</p>
|