http://mtaalamu.ru
На стороне сервера использую Node.js, развивающийся в последние месяцы просто космическими темпами. На стороне же клиента — не менее интенсивно развивающийся jQuery, который, помимо возможности рисовать красивые интерфейсы, содержит мощные средства выполнения асинхронных запросов. Ну, а посредником между клиентом и сервером может выступать код в формате JSON (я и раньше его иногда использовал, в GWT для этого есть необходимые пакеты).
Вот как можно организовать передачу JSON-объекта на сервер. На стороне клиента:
var queryParams = {greeting: 'Hello, World!', someBool: true};
$.getJSON('/hello', queryParams, function(data){
// асинхронный разбор прилетевшего с сервера JSON-объекта.
}
Как принять на стороне сервера (задействован пакет express):
app.get('/hello', function (req, res) {
res.setHeader('Content-Type', 'application/json; charset=utf-8');
var someObject = {
replay: 'Воистину ' + req.query.greeting,
yesOrNo: req.query.someBool
};
res.send(JSON.stringify(someObject));
}
Вот так, довольно бесхитростно. Учитывая то, что с сервера можно присылать довольно сложные объекты, этот метод вполне может заменить GWT в экспресс-проектах, когда городить огород некогда и незачем.]]>
developer.yahoo.com/yui/compressor/
Скачиваем архив здесь:
yuilibrary.com/downloads/#yuicompressor
В архиве в директории build будет уже собранный jar файл. Запускаем его так:
java -jar yuicompressor-x.y.z.jar --type js --charset utf-8 --nomunge --preserve-semi --disable-optimizations исходный-скрипт.js -o сжатый-скрипт.js
Без ключа --nomunge код будет немножечко обфусцирован.]]>
Один хороший человек создал online-сервис для генерирования маркеров. От рисования иконки он не освобождает, но вот тень и javascript-код формируются автоматически, и это экономит много времени.]]>
На сайте выложен бинарник для MS-DOS(!), но поскольку программа чрезвычайно проста, ее можно за несколько секунд откомпилировать для Linux не меняя ни строчки кода. Исходник можно взять здесь, далее все просто:
gcc -o jsmin jsmin.c ; sudo mv jsmin /usr/bin
Пользоваться так:
jsmin < fat.js > mini.js
Пропущенный через JSMin js-файл «похудел» раз в 5-6. Меня такой показатель вполне устраивает.]]>