|
|
|
| кто сможет объяснить, почему это работает (т.е.Hello! на странице появляется):
<body>
<script>
<!--
document.write ("<script>document.write ('Hello!')</script>");
-->
</script>
</body>
|
а точно такое же, но БЕЗ переносов строк внутри комментария - НЕ работает (страница остаётся девственно чистой)
<body>
<script>
<!-- document.write ("<script>document.write ('Hello!')</script>"); -->
</script>
</body>
|
консоль ошибок в обоих случаях "молчит как немая"
PS. тег комментария внутри скриптового блока в данном случае предназначены не для защиты от мифических браузеров, которые "не понимают" яваскрипта, а именно и только для того, чтобы не "разбивать на части" закрывающий тег </script> внутри метода write () | |
|
|
|
|
|
|
|
для: яса_1
(18.04.2015 в 09:21)
| | Есть много, друг Горацио, на свете,
что и не снилось нашим мудрецам... (C)
А почему один перенос перед тэгом <img.. > приводит (сейчас не знаю, но раньше точно) к появлению 1px-й полоски перед ним? Перенос в коде! А почему /* (комментарий), если он написан /** уже по-другому читает класс? | |
|
|
|
|
|
|
|
для: elenaki
(18.04.2015 в 12:40)
| | по поводу "полоски" перед <img> - это я знаю
во-первых, она не однопиксельная, ширина её зависит от установленного в родителе размера шрифта
во-вторых, всякий перенос в html-коде преобразуется в пробел, а любое количество (> 0) пробельных символов подряд преобразуется в один неразрывный пробел
так что в итоге перенос перед <img> - это "неразрывный пробел перед img" (типа <img>) | |
|
|
|
|
|
|
|
для: яса_1
(18.04.2015 в 09:21)
| |
<script>
document.write ("<script>document.write ('Hello!')<\/script>");
</script>
|
| |
|
|
|
|
|
|
|
для: confirm
(18.04.2015 в 17:26)
| | ладно, упрощаю вопрос, ибо сути его вы не поняли, увы
почему
<script>
<!--
alert ('работает');
-->
</script>
|
а вот это
<script>
<!-- alert ('НЕ работает'); -->
</script>
|
| |
|
|
|
|
|
|
|
для: яса_1
(19.04.2015 в 00:52)
| | В первом случае код javascript содержит 3 строки, первую и третью интерпретатор игнорирует, так как они некорректные, а вторую исполняет.
Во втором случае одна строка и javascript ее полностью игнорирует, т.к. не понимает, что такое "<!--" и "-->". | |
|
|
|
|
|
|
|
для: Mookapek
(19.04.2015 в 03:26)
| | неверно, потому что консоль ошибок молчит
проверьте
<script>
хрень любая
alert ('НЕ работает');
</script>
|
консоль сразу же укажет на ошибку в первой строке с записью SyntaxError: missing ; before statement и вторая строка с алертом исполняться уже не будет | |
|
|
|
|
|
|
|
для: яса_1
(19.04.2015 в 05:26)
| | <!--alert('НЕ работает')--> - здесь ведь нет ошибки, вся строка это комментарий, поэтому и не исполняется. А так:
<!--
alert('НЕ работает')-->
уже будет генерироваться ошибка - не найден завершающий дескриптор.
Все это особенности JS, каждая команда с новой строки, а в JS их можно не завершать точкой с запятой:
<!-- alert ... - это комментарий и нет команд
<!-- это комментарий
alert ... а это уже команда | |
|
|
|