Показать полную графическую версию : Фоновая работа JS-скрипта в GreaseMonkey
System Failure
22-07-2009, 18:30
Доброго времени суток, уважаемые.
Пишу скрипт для GreaseMonkey, который собирает некую информацию со страницы, сохраняет её, обновляет страницу, ищет новую информацию, сохраняет её, обновляет страницу и т.д. Все в принципе не сложно. Однако проблема в том, что для того чтобы скрипт работал - страница всегда должна быть открыта. Хочется сделать чтобы скрипт выполнялся в Background'е, не влияя на работу пользователя на этой же страничке или не требуя отдельно открытого окна пока пользователь и так работает под необходимым доменом. Я без понятия как это можно было бы организовать. Если у кого есть идеи - был бы очень признателен. Желательно с простейшими примерами, чтобы я смог не только слизать готовый материал, а понять как это работает.
З.Ы.: с аяксом не знаком, но похоже что в скриптах, в которых подобная технология организована - используется нечто подобное.
Решил подробнее объяснить суть того что я хочу:
Скрипт должен собирать информацию с некоторой странички http://some_domain/some_page.
Пока пользователь и так находится на http://some_domain/ у него появляется небольшое меню с кнопками "Старт" "стоп" "показать инфо". При нажатии на "старт" скрипт начинает работать и раз в "Н"-ое количество минут собирает обновленную информацию с http://some_domain/some_page, причем пока он собирает - это не должно влиять на работу пользователя на http://some_domain/.
AJAX + скрипт на стороне сервера. Реализация зависит от инструментов (библиотек) JS которые вы используете, и серверного языка...
Для начала лучше поискать готовые решения...
System Failure
22-07-2009, 19:39
скрипт на стороне сервера отпадает. к нему, к серверу, естественно, доступа нет, иначе не было бы смысла для этого писать ГризМанковый скрипт, а можно было бы все функции встроить непосредственно в сам сайт. в том то и дело, что в аналогичных скриптах это как-то организованно без участия сервера в этом процессе.
System Failure, это скрипт, устанавливамый в браузер?
в общем готовых вариантов полно... http://userscripts.org/scripts/search?q=ajax
цикличность достигается функцией setInterval (https://developer.mozilla.org/en/DOM/window.setInterval)
фоновая работа - асинхронный XMLHttpRequest (https://developer.mozilla.org/ru/XMLHttpRequest), для greasemonkey GM_xmlhttpRequest (http://diveintogreasemonkey.org/api/gm_xmlhttprequest.html)
System Failure
22-07-2009, 23:50
спасибо за инфо. выглядит просто - как опробую, отпишу результат :)
System Failure
24-07-2009, 00:55
в общем все почти получилось :) проблема в том, как теперь в полученном в ответе ХТМЛе искать необходимые мне данные? можно создать некий контейнер <div> и присвоить div.innerHTML = responseDetails.responseText; но проблема в том, что добавляя этот div в document.body.appendChild(div); - даже скрывая его отображение через setAttribute("style","display:none"); - скрипты выполняемые внутри этого div вызывают ошибки, негативно влияющие на работу странички.
div.innerHTML = responseDetails.responseText; »
ответ содержит страницу целиком, поэтому его в DOM нельзя встраивать, нужно ответ предварительно очистить от ненужных тегов (head с содержимым, body, script, iframe и тд), либо вытащить необходимые теги. Все это с помощью регулярных выражений в replace (https://developer.mozilla.org/en/Core_JavaScript_1.5_Reference/Global_Objects/String/replace) делается.
System Failure
24-07-2009, 14:17
Все это с помощью регулярных выражений »
Никогда с регулярными выражениями до этого не работал... По всей видимости крайне удобная штуковина. Пытался разобраться - сам тэг удалить не проблема, но как удалить информацию находящуюся между открывающим и закрывающим тэгом? Лучше не давать мне готовый результат, а просто направить в нужное русло. Я думал что это лучше всего сделать через lastIndex открывающего и lastIndex закрывающего тэга. И затем все что находится между этими индексами стереть...
чтобы вытащить содержимое тега body можно сделать так
var bodytext_arr = responseDetails.responseText.match(/<body[^>]*>([\s\S]*?)<\/body>/i);
var bodytext = (bodytext_arr) ? bodytext_arr[1] : 'В страничке нет тега body';
div.innerHTML = bodytext;
для удаления тега с содержимым можно использовать примерно такое же регулярное выражение в replace...
реализация зависит от условий и понимания того, что нужно в конечном итоге...
System Failure
25-07-2009, 00:26
(/<body[^>]*>([\s\S]*?)<\/body>/i) »
можно, пожалуйста, если это не составит большого труда, пояснить синтаксис этого выражения?
я его понял так:
/<body - начало тэга, все понятно.
[^>] исключаем из искомого символ > - зачем?
*> - повторение неких предшествующих элементов ноль или более раз, затем символ ">" (тоже не совсем понятно зачем вначале исключать, потом опять включать символ ">")
([\s\S]*?) - набор любых символов неограниченое количество раз (зачем "?", почему не достаточно одной "*" и для чего заключать всё это в круглые скобки?)
<\/body>/i - ищем закрывающий тэг, и чтобы "/" воспринимался литерально - используется перед ним "\". i - для не зависимости от регистра.
Заранее огромное спасибо. Объяснять не обязательно, может со временем сам разберусь, но если найдете свободную минуту, был бы очень благодарен.
Добавлено:
Просмотрев как работает этот код, теперь кажется понял зачем круглые скобки... Таким образом для вывода сохраняются только данные, попадающие под "[\s\S]*?", тогда как сами тэги исключаются.
[^>] исключаем из искомого символ > - зачем? »
[] - символьный класс (внутри набор символов), если ^ в начале, то означает "все символы кроме указанных", * - квантификатор повторения (от 0 до бесконечности). Т.е. означает повторение всех символов, кроме > от 0 до бесконечности...
([\s\S]*?) »
тупо - все символы подряд (пробельные и непробельные), *? - инвертирует жадность квантификатора - т.е. берет минимально-возможное кол-во символов. () - подмаска, то что внутри идет в переменную (номер - позиция подмаски)... вот тут (http://javascript.ru/RegExp) можно почитать...
© OSzone.net 2001-2012
vBulletin v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.