![]() |
Фоновая работа JS-скрипта в GreaseMonkey
Доброго времени суток, уважаемые.
Пишу скрипт для GreaseMonkey, который собирает некую информацию со страницы, сохраняет её, обновляет страницу, ищет новую информацию, сохраняет её, обновляет страницу и т.д. Все в принципе не сложно. Однако проблема в том, что для того чтобы скрипт работал - страница всегда должна быть открыта. Хочется сделать чтобы скрипт выполнялся в Background'е, не влияя на работу пользователя на этой же страничке или не требуя отдельно открытого окна пока пользователь и так работает под необходимым доменом. Я без понятия как это можно было бы организовать. Если у кого есть идеи - был бы очень признателен. Желательно с простейшими примерами, чтобы я смог не только слизать готовый материал, а понять как это работает. З.Ы.: с аяксом не знаком, но похоже что в скриптах, в которых подобная технология организована - используется нечто подобное. Решил подробнее объяснить суть того что я хочу: Скрипт должен собирать информацию с некоторой странички http://some_domain/some_page. Пока пользователь и так находится на http://some_domain/ у него появляется небольшое меню с кнопками "Старт" "стоп" "показать инфо". При нажатии на "старт" скрипт начинает работать и раз в "Н"-ое количество минут собирает обновленную информацию с http://some_domain/some_page, причем пока он собирает - это не должно влиять на работу пользователя на http://some_domain/. |
AJAX + скрипт на стороне сервера. Реализация зависит от инструментов (библиотек) JS которые вы используете, и серверного языка...
Для начала лучше поискать готовые решения... |
скрипт на стороне сервера отпадает. к нему, к серверу, естественно, доступа нет, иначе не было бы смысла для этого писать ГризМанковый скрипт, а можно было бы все функции встроить непосредственно в сам сайт. в том то и дело, что в аналогичных скриптах это как-то организованно без участия сервера в этом процессе.
|
System Failure, это скрипт, устанавливамый в браузер?
в общем готовых вариантов полно... http://userscripts.org/scripts/search?q=ajax цикличность достигается функцией setInterval фоновая работа - асинхронный XMLHttpRequest, для greasemonkey GM_xmlhttpRequest |
спасибо за инфо. выглядит просто - как опробую, отпишу результат :)
|
в общем все почти получилось :) проблема в том, как теперь в полученном в ответе ХТМЛе искать необходимые мне данные? можно создать некий контейнер <div> и присвоить div.innerHTML = responseDetails.responseText; но проблема в том, что добавляя этот div в document.body.appendChild(div); - даже скрывая его отображение через setAttribute("style","display:none"); - скрипты выполняемые внутри этого div вызывают ошибки, негативно влияющие на работу странички.
|
Цитата:
|
Цитата:
|
чтобы вытащить содержимое тега body можно сделать так
Код:
var bodytext_arr = responseDetails.responseText.match(/<body[^>]*>([\s\S]*?)<\/body>/i); реализация зависит от условий и понимания того, что нужно в конечном итоге... |
Цитата:
я его понял так: /<body - начало тэга, все понятно. [^>] исключаем из искомого символ > - зачем? *> - повторение неких предшествующих элементов ноль или более раз, затем символ ">" (тоже не совсем понятно зачем вначале исключать, потом опять включать символ ">") ([\s\S]*?) - набор любых символов неограниченое количество раз (зачем "?", почему не достаточно одной "*" и для чего заключать всё это в круглые скобки?) <\/body>/i - ищем закрывающий тэг, и чтобы "/" воспринимался литерально - используется перед ним "\". i - для не зависимости от регистра. Заранее огромное спасибо. Объяснять не обязательно, может со временем сам разберусь, но если найдете свободную минуту, был бы очень благодарен. Добавлено: Просмотрев как работает этот код, теперь кажется понял зачем круглые скобки... Таким образом для вывода сохраняются только данные, попадающие под "[\s\S]*?", тогда как сами тэги исключаются. |
Цитата:
Цитата:
|
Время: 10:07. |
Время: 10:07.
© OSzone.net 2001-