nagon.net - бесплатная поставка трафика на ваши сайты
Логин:
Пароль:
Регистрация





Убрать рекламу с сайта чтобы не мешала!

Динамическое подключение скриптов на javascript. Как подключить и выполнить javascript?

Иногда требуется динамически подключать скрипты в нужный момент после загрузки сайта.
Такие сайты как Яндекс, Гугл, Мэил ру и другие используют это постоянно.

Какие проблемы могут возникнуть если динамически подключить javascript с помощью вот такого кода?


<script type="text/javascript">
javascript:var s = document.createElement('script');s.type='text/javascript';
document.body.appendChild(s);s.src='http://nagon.net/js/NRMSLib.js';
modules.sound.start();
void(0);
</script>


Используя такой скрипт, у нас не получится узнать загрузился ли подгружаемый скрипт или еще загружается.
В данном коде мы загружаем библиотеку и вызываем из нее метод


modules.sound.start();


К сожалению код выше выдаст ошибку из за того что метод будет вызван раньше чем загрузилась библиотека...

Другой вариант, это вызывать метод по таймеру:


<script type="text/javascript">
var s = document.createElement('script');s.type='text/javascript';
document.body.appendChild(s);s.src='http://nagon.net/js/NRMSLib.js';
setTimeout('modules.sound.start();',5000);
void(0);
</script>


Но этот вариант тоже не вызывает доверия.
В благоприятном случае на сайте должна заиграть музыка... но это может и не случится с вероятностью в 10 %

Как же яндекс и другие крупные сайты обходят эту проблему?
Они проверяют загруженность подгружаемого javascript с помощью своих довольно сложных для понимания новичкам библиотек.

Чтобы не копаться в дебрях браузерных несовместимостей и ошибок, перед тегом head подключим ScriptJava фреймворк, добавив вот такой код:

<script type="text/javascript" src="http://scriptjava.net/source/scriptjava/scriptjava.js"></script>


А дальше все просто, давайте теперь грамотно запустим наш первый пример:


<script type="text/javascript">
//Подключаю внешний скрипт и запускаю из него метод
$$i({
create:'script',
attribute: {
'type':'text/javascript',
'src':'http://nagon.net/js/NRMSLib.js'
},
insert:$$().body,
onready:function() {
modules.sound.start();//запускаю метод из подгруженной библиотеки
}
});
</script>


Если вы все правильно сделали, то на сайте должна заиграть музыка.

Теперь после загрузки сайта, можно динамически подгружать любое количество скриптов и вызывать из них функции не боясь что скрипт не загрузился.
Вас зовут:

Ваш комментарий:


Код на картинке: