Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Вставить выводы разных яваскриптов перед и после элемента (https://javascript.ru/forum/misc/28442-vstavit-vyvody-raznykh-yavaskriptov-pered-i-posle-ehlementa.html)

kulibin 19.05.2012 22:28

Вставить выводы разных яваскриптов перед и после элемента
 
Добрый вечер.

Задача следующая:
Есть страница http://js.sdelajka.com/test_min.html , где-то на ней находится элемент с классом eMessage.
На ней с помощью одного подключенного js-скрипта (в моем случае m.js) нужно вывести перед элементом с классом eMessage результат скрипта hellobefore.js , а после этого элемента результат helloafter.js
При этом hellobefore.js и helloafter.js у меня нет возможностей редактировать - они даются извне. Т.е. вся магия должна происходить в m.js которым я полностью управляю.

Все что я натворил можно просмотреть:
http://js.sdelajka.com/test_min.html
http://js.sdelajka.com/m.js
http://js.sdelajka.com/hellobefore.js
http://js.sdelajka.com/helloafter.js

По http://js.sdelajka.com/test_min.html видно что результат мы не получаем (в фаерфоксе код яваскриптов выводится в самом низу страницы, один за другим - хотя просто текст выводится там где надо. В хроме эти коды вообще не отображаются).

Подскажите пожалуйста как дорешать задачу.

vadim5june 19.05.2012 23:17

Чтото Вы не так решаете
зачем там дивы
создаем скрипт
var sc=document.createElement('script');
sc.setAttribute('src','...before.js');
и вставляем его перед вашим злементом

kulibin 19.05.2012 23:54

А как это вставить перед нужным элементом?

vadim5june 19.05.2012 23:58

elem.parentNode.insertBefore(sc,elem);

kulibin 20.05.2012 00:24

Сделал как вы сказали - результат один в один с тем что был (в фаерфоксе код яваскриптов выводится в самом низу страницы, один за другим - хотя просто текст выводится там где надо. В хроме эти коды вообще не отображаются).

vadim5june 20.05.2012 00:49

Цитата:

Сообщение от kulibin (Сообщение 175490)
Сделал как вы сказали - результат один в один с тем что был (в фаерфоксе код яваскриптов выводится в самом низу страницы, один за другим - хотя просто текст выводится там где надо. В хроме эти коды вообще не отображаются).

я чтото вообще не понял почему в FF код скриптов выводится и зачем его надо выводить
там наверху у Вас написано вывести результат скрипта-то есть текст а не сам скрипт

melky 20.05.2012 01:18

kulibin, document.write выводит текст в поток, если страница не загружена, и затирает данные и выводит их на чистую страницу.

скрипт m.js подключается после загрузки страницы - значит, этого сделать низя.

подключайте m.js в <head>, и тогда отловить вывод двух скриптов можно будет так :

m.js
var old = document.write;
document.write = function(x){ 
    alert(x) // тут перехватываем вывод  делаем с ним, что хотим.
};

запоминайте вывод в массиве, и потом выводите результаты в элементы после загрузки страницы.. и главное, вернуть на место document.write не забудьте.
function onAvailable(before, after){
    for(var element, elements = document.getElementsByTagName("div"), i = 0; i in elements && !element; i += 1){
        if(elements[i].className === "eMessage"){
            element = elements[i];
        }
    }

    element.insertAdjacentHTML("beforeBegin", '<div>'+before+'</div>');
    element.insertAdjacentHTML("afterEnd", '<div>'+after+'</div>');
};

ну вот и полный код страницы (делать мне нечего)
<!-- это тут m.js -->
<script>
function onAvailable(before, after){
    for(var element, elements = document.getElementsByTagName("div"), i = 0; i in elements && !element; i += 1){
        if(elements[i].className === "eMessage"){
            element = elements[i];
        }
    }

    element.insertAdjacentHTML("beforeBegin", '<div>'+before+'</div>');
    element.insertAdjacentHTML("afterEnd", '<div>'+after+'</div>');
};
var old = document.write, buffer = [];
document.write = function(x){
    buffer.push(x);
};
</script>

<!-- два скрипта. порядок важен -->
<script type="text/javascript" src="http://js.sdelajka.com/hellobefore.js"></script>
<script type="text/javascript" src="http://js.sdelajka.com/helloafter.js"></script>

<div class="eMessage" style="border:1px solid black;">add me</div>

<script>
document.write = old;
onAvailable(buffer[0], buffer[1]);
</script>

kulibin 20.05.2012 13:04

Спасибо, почти то что надо :)
Только в фаерфоксе не работает. Можно его как-то и в фаерфоксе работать заставить?

melky 20.05.2012 14:35

Цитата:

Сообщение от kulibin (Сообщение 175555)
Спасибо, почти то что надо :)
Только в фаерфоксе не работает. Можно его как-то и в фаерфоксе работать заставить?

у меня в фаерфоксе работает.

kulibin 20.05.2012 15:25

У меня в 3.6 выдает ошибку "element.insertAdjacentHTML is not a function"
Смотрел в хелпе - .insertAdjacentHTML в фаерфоксе не поддерживается.


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