aboutsummaryrefslogtreecommitdiff
path: root/files/ru/web/api/childnode/remove/index.html
blob: ff5b20cc2d5b0f5952229994deb6f6a4d337b933 (plain)
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
---
title: Node.remove()
slug: Web/API/ChildNode/remove
translation_of: 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>&lt;div id="box"&gt;
   &lt;div id="one"&gt;&lt;/div&gt;
   &lt;div id="two"&gt;&lt;/div&gt;
&lt;/div&gt;</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>{{CompatibilityTable}}</p>

<table class="compat-table">
 <tbody>
  <tr>
   <th>Особенность</th>
   <th>Chrome</th>
   <th>Firefox (Gecko)</th>
   <th>Internet Explorer</th>
   <th>Opera</th>
   <th>Safari</th>
  </tr>
  <tr>
   <td>Базовая поддержка {{domxref("Element")}}</td>
   <td>23.0</td>
   <td>{{CompatGeckoDesktop("23.0")}}</td>
   <td>{{CompatNo}}</td>
   <td>10.0</td>
   <td>7.0</td>
  </tr>
  <tr>
   <td>Поддержка {{domxref("CharacterData")}} и {{domxref("DocumentType")}}</td>
   <td>29.0</td>
   <td>{{CompatGeckoDesktop("23.0")}}</td>
   <td>{{CompatNo}}</td>
   <td>16.0</td>
   <td>7.0</td>
  </tr>
 </tbody>
</table>

<table class="compat-table">
 <tbody>
  <tr>
   <th>Особенность</th>
   <th>Android</th>
   <th>Firefox Mobile (Gecko)</th>
   <th>IE Mobile</th>
   <th>Opera Mobile</th>
   <th>Safari Mobile</th>
  </tr>
  <tr>
   <td>Базовая поддержка {{domxref("Element")}}</td>
   <td>{{CompatVersionUnknown}}</td>
   <td>{{CompatGeckoMobile("23.0")}}</td>
   <td>{{CompatNo}}</td>
   <td>10.0</td>
   <td>{{CompatNo}}</td>
  </tr>
  <tr>
   <td>Поддержка {{domxref("CharacterData")}} и {{domxref("DocumentType")}}</td>
   <td>{{CompatVersionUnknown}}</td>
   <td>{{CompatGeckoMobile("23.0")}}</td>
   <td>{{CompatNo}}</td>
   <td>16.0</td>
   <td>{{CompatNo}}</td>
  </tr>
 </tbody>
</table>