Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   defer (https://javascript.ru/forum/misc/2536-defer.html)

Dr_VOLAND 12.01.2009 01:08

defer
 
Господа вот код, в нем хочет работать innerHTML, что не так? =(

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<title>Untitled Document</title>
<script type="text/javascript">
window.onload = function() {
	document.getElementById('clicker').onclick = swop;
}
function swop() 
{
/*var sScript="<SCRIPT DEFER>";
sScript = sScript + " document.write("Hello World!"); ";
sScript = sScript + "</SCRIPT" + ">";*/

this.innerHTML = '<script type="text/javascript" defer="true"><!--document.write("Hello World!");\/\/--><\/script>';
}
</script>
<style type="text/css">
div {
padding:20px;
margin:20px;
border:1px solid #000;
}
</style>
</head>

<body>
<div id="clicker">click me to change me</div>
</body>
</html>


Спасибо!

Ilya 12.01.2009 02:27

Dr_VOLAND,

Если убрать комментарии из сценария (<script type="text/javascript" defer="true"><!--document.write("Hello World!");\/\/--><\/script>), и перед этим сценарием, но после одинарной кавычки поставить любой символ ('1<script) (Сам не понимаю, для чего это нужно), то в IE срабатывает. В других браузерах не работает.

Я предполагаю, что этом может быть связано с атрибутом defer. Насколько я знаю, этот атрибут обязательно следует вставлять в <script>, если он создается через innerHTML. К тому же он поддерживается только в IE.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<title>Untitled Document</title>
<script type="text/javascript">
window.onload = function() {
document.getElementById('clicker').onclick = swop;
}
function swop()
{
/*var sScript="<SCRIPT DEFER>";
sScript = sScript + " document.write("Hello World!"); ";
sScript = sScript + "</SCRIPT" + ">";*/

this.innerHTML = '1<script type="text/javascript" defer="true">document.write("Hello World!");\/\/<\/script>';
}
</script>
<style type="text/css">
div {
padding:20px;
margin:20px;
border:1px solid #000;
}
</style>
</head>

<body>
<div id="clicker">click me to change me</div>
</body>
</html>

War Hammer 13.01.2009 18:58

попробуй это не знаю будет пахать или нет:

var o = window.document.createElement("SCRIPT");
o.text = "document.write('Hello World!');";
window.document.body.insertBefore(o);


Часовой пояс GMT +3, время: 00:09.