Чому "aaa" залишається?
В прикладі нижче виклик table.remove()
має видалити таблицю з документу.
Але, якщо ви запустите код, то побачите, що текст "aaa"
не зникає.
Чому так відбувається?
<table id="table"> aaa <tr> <td>Тест</td> </tr> </table> <script> alert(table); // таблиця, як і має бути table.remove(); // чому текст "aaa" залишився в документі? </script>
HTML в завданні написаний невірно. Це і є причиною дивної поведінки коду.
Браузер має виправити це автоматично. Але згідно специфікації тег <table>
може містити в собі лише теги які відносяться до таблиць. Тому браузер виносить "aaa"
перед тегом <table>
.
Тепер очевидно, що коли ми видаляємо таблицю, текст залишається
Можна легко відповісти на це запитання, дослідивши DOM за допомогою інструментів веб-розробки в браузері. Ви побачите "aaa"
перед <table>
.
В стандартах HTML детально описано як обробляти некоректний HTML, тому така поведінка браузера є правильною.