Пишу, по большей части, про историю, свою жизнь и немного про программирование.

User.js и FF

Сегодня написал небольшой user.js для «Оперы» и решил его переписать под плагин «Greasemonkey», под «Firefox». Оказалось, что есть немаловажные различия.

Во-первых, объект window браузера напрямую недоступен — нужно пользоваться «unsafeWindow», но руководство не рекомендует его использовать. Мне в user.js window браузера нужен был для доступа к jQuery, который был подгружен на странице, где работает скрипт, мне было удобно использовать этот framework. Объект «window» тоже есть, это внутренний объект Greasemonkey и выглядит как настоящий, только не радует на него, например, рекомендуется вешать все события.

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

location.href="javascript:void(pageFunc(123))"

, утвержается, что это более безопасно, видимо, чтобы не передавать контекст выполнения наружу. Говорят, что в Chrome 4 это единственный способ добраться до «window».

В-третьих, из скриптов, выполняющихся из Greasemonkey, можно использовать функции «GM_xmlhttpRequest» (XHR с возможностью делать запросы на любые адреса), «GM_log» (логгирование, как можно догадаться) и так далее.

Ну и можно использовать localStorage (FF 3.5+) и globalStorage (FF 2.0+) для сохранения данных user.js.

8 комментариев
arty (arty.name) 2009

я тут тоже недавно возился с переносом userjs из оперы в хром и фф. В хром всё получилось достаточно быстро унести, хотя невозможность присваивать innerHTML для head меня серьёзно удивила. А вот гризманки со своей сверхзаботливостью — порождение дьявола. В итоге я просто сделал вот что: в юзерскрипте объявлена функция, и скрипт просто вставляет её .toString() в тело документа и запускает его.

кстати, проблем с window в хроме я не замечал. Может, я его особо не использую, не знаю…

ELV1S (elv1s.ru) 2009

Возможно, в Greasemonkey 1.0 удастся избавится от unsafeWindow http://groups.google.com/group/greasemonkey-dev/browse_thread/thread/9f74ff190736f179

У меня были проблемы с location.href=«javascript:void(pageFunc(123))» (он же location hack) в Firefox-е. Marti Martz, активный коммитер Greasemonkey, сказал: «Please note that the location hack only works under certain platforms. Nix for example won’t support this fully in the Firefox distro.» http://github.com/NV/nice-alert.js/issues/#issue/6 . Это похоже на правду.

(в «Опере» для этого можно использовать opera.io.filesystem)

Это же только в виджетах и юнайт приложениях. Или я не знаю чего?

ELV1S (elv1s.ru) 2009

Комментарий для arty.name:

кстати, проблем с window в хроме я не замечал. Может, я его особо не использую, не знаю…

Пока ты не используешь переменные внутри window (исключая document), проблем нет.

Евгений Степанищев (bolknote.ru) 2009

Комментарий для elv1s.ru:

Это же только в виджетах и юнайт приложениях. Или я не знаю чего?

Я попробовал на скорую руку, у меня вышло. Или я что-то неаккуратно сделал и принял желаемое за действительное? Если попробуешь и не выйдет, дай знать.

ELV1S (elv1s.ru) 2009

Комментарий для Евгения Степанищева:

http://userscripts.ru/js/opera.io.filesystem.js говорит, что opera.io.filesystem undefined.

Евгений Степанищев (bolknote.ru) 2009

Комментарий для elv1s.ru:

Ага, спасибо. Странно.

ELV1S (elv1s.ru) 2009

Комментарий для arty.name:

в юзерскрипте объявлена функция, и скрипт просто вставляет её .toString() в тело документа и запускает его.

Этот метод намного легче дебажить, чем location hack. Спасибо!

arty (arty.name) 2009

Комментарий для elv1s.ru:

Возможно, в Greasemonkey 1.0 удастся избавится от unsafeWindow

это было бы очень круто!