JavaScript Image Optimiser (JSIO)

So, I’ve embarked on a new mini project. It is kind of inspired by image sprites.

Image sprites are a great idea, but come with a whole bunch of issues that make them a bit of a pain to work with.

Firstly, most of the time you have to use markup to create an element in html to “hold” the image you wanted to display from your sprite. This is because if you actually set a sprite as the background image for a large html element you’re likely to see other images in the sprite as well. Because of this, you actually lose useful functionality that CSS gives you, like the ability to position, repeat and scale an image. Also, the markup you’ve created to hold the image exists for style purposes, which is bad.

Secondly, sprites can be a massive ball ache to maintain. If you’ve closely packed your images in a sprite for maximum efficiency and then one of your images needs to change size, you’re either going to have to move ALL images surrounding the image you have to update (and obviously then change all background-position properties for the images you’ve moved) or leave a space and put the updated image in a new position in your sprite.

How do you know which images in a sprite are used and which ones are dead? Since your images are referenced by coordinates, this sort of clean up becomes a nightmare and is actually a bit lot of a nightmare to create image sprites in the first place.

The goals of the project are to

  1. Reduce the number of http requests (and their associated header traffic) to the server and hence reduce the time it takes to load all images on a website and bandwidth footprint the site requires
  2. Create a solution that’ll alleviate some of the problems surrounding the creation and use of image sprites
  3. Do something cool

The JSIO project website has a pretty good explanation of how it works so I won’t bore you with the details here. However, as a brief overview, it packages all your image data in data uri format and you reference particular images by their filename rather than their coordinates.

The site actually uses the HTML5 file api to generate your resources file for you, which makes creating and maintaining your JSIO “sprite” really really easy.

I read *somewhere* that data uri encoded images can be up to 1/3 larger than corresponding image files, however with gzip encoding they can be only 0-3% larger (or less). My thesis is that for a site with many small images, JSIO could be more efficient and easier to maintain than having separate files or even an image sprite.

…I’m yet to prove or disprove this and I’ll be conducting some tests whose results I’ll post up here (even if they do prove JSIO to be useless).

Disclaimer: This is the first ever ALPHA release of JSIO – it works on the latest Firefox and Chrome but I haven’t even checked it in IE yet. It probably won’t work in IE yet. Also, the website needs some work for optimal display on mobile devices.

5,488 thoughts on “JavaScript Image Optimiser (JSIO)

  1. Roseline — ивановская студия флористики с полным спектром услуг: от авторских букетов до оформления торжеств. В наличии розы, пионовидные тюльпаны, гортензии, эустомы, герберы, лилии и редкие ранункулюсы. На https://roseline37.ru/ представлен полный каталог с актуальными ценами — заказ оформляется онлайн с доставкой по городу. Помимо срезанных цветов студия предлагает съедобные букеты, сухоцветы, кашпо и оформление торжеств любого масштаба. Каждая композиция создаётся вручную опытными флористами строго по пожеланиям заказчика.

  2. Объём шеринговой экономики в России достиг 1 трлн рублей и демонстрирует устойчивый рост. Тулбокс закрепился в этом сегменте с форматом проката инструмента через постаматы — без персонала, без залога и лишних формальностей. Клиент берёт дрель или пылесос через приложение в боксе у «Пятёрочки» или ПВЗ рядом с домом. Подробности партнёрства — на https://biz.tlbx.ru/ — инвестиции от 3 млн рублей с окупаемостью 18–24 месяца. Компания развёрнута в трёх крупных городах и открыта для партнёров готовых запустить сервис на своей территории.

  3. WBDown — мощный инструмент для продавцов и аналитиков Wildberries: даёт возможность оперативно выгружать артикулы товаров по ID продавца или URL магазина с удобной сортировкой по популярности, рейтингу, цене и новинкам. Ищете конвертировать видео из отзывов вб в mp4? Сервис wbdown.ru предлагает удобный парсинг до 1000 артикулов за раз по цене от 2 рублей за артикул, проверку фото на контент 18+ и фоновую обработку данных — всё необходимое для глубокого анализа конкурентов и оптимизации продаж. именно то что нужно для детального изучения конкурентов и повышения эффективности продаж.

  4. Эта публикация погружает вас в мир увлекательных фактов и удивительных открытий. Мы расскажем о ключевых событиях, которые изменили ход истории, и приоткроем завесу над научными достижениями, которые вдохновили миллионы. Узнайте, чему может научить нас прошлое и как применить эти знания в будущем.
    Хочешь знать всё? – наркология вызов на дом

  5. «Мой Токио» — туроператор с фокусом на Японии, предлагающий россиянам групповые, индивидуальные и корпоративные туры на любой запрос. В ассортименте — маршруты по Токио, Киото, Осаке, Хиросиме и другим регионам страны, горнолыжный и пляжный отдых на Окинаве, а также программы обучения в Японии. Ищете экскурсии в кагосима на русском языке? На dvmt.ru собраны актуальные путёвки и горячие туры с профессиональным сопровождением. Оператор зарегистрирован официально под номером РТО 004645 — это подтверждает надёжность компании и безопасность каждого тура.

  6. Точность до микрона и строгое соответствие техническому заданию — именно это отличает настоящее производство от кустарной мастерской. Компания «Металлообработка-ЗР» выполняет изготовление деталей на заказ по чертежам в Москве, работая с металлами любой сложности и обеспечивая стабильно высокое качество на каждом этапе. Подробный каталог услуг, актуальные цены и реальное портфолио готовых работ доступны на сайте https://metalloobrabotka.org/ — здесь же можно оформить заявку или заказать обратный звонок от специалиста. Собственное оборудование, сертифицированное производство и гарантия на выполненные работы делают компанию надёжным партнёром для бизнеса.

  7. Этот увлекательный информационный материал подарит вам массу новых знаний и ярких эмоций. Мы собрали для вас интересные факты и сведения, которые обогатят ваш опыт. Откройте для себя увлекательный мир информации и насладитесь процессом изучения!
    Всё, что нужно знать – нарколога домой

  8. у разных селеров бывает разный джив имеется виду по качеству так я как то брал джив к10 пер слабо очень в другом к 15 убивал вот и спрашивают всегда качество дживика у продавана если ты незнал Купить Кокаин Купить Мефедрон черт возьми вот сейчас оформляю AM2233 и решил заглянуть сюда.Может стоит внимательно посмотреть в ветке что есть резервный жаббер ? основной уже 6 дней не работает какие то сбои но резерв ведь работает привыкли панику поднимать на ровном месте.

  9. WOW just what I was searching for. Came here by searching for meta_keyword buy xanax without prescrition sexual porn pills

  10. This info is invaluable. How can I find out more? Buy Tadalafil Online anal sex xxx porn pills

  11. В этом обзорном материале представлены увлекательные детали, которые находят отражение в различных аспектах жизни. Мы исследуем непонятные и интересные моменты, позволяя читателю увидеть картину целиком. Погрузитесь в мир знаний и удивительных открытий!
    Интересует подробная информация – вызов на дом капельницы от запоя

  12. Работала с данным магазином давным давно Пожалуй самый лучший https://kypitmarixyany.shop Плохует мягко сказаноуже больше пол месяца жду.Тебе кстати пришла?Клад был сделано на 5 инфу по кладу дали на 5. В общем очень доволен данным магазином по качеству товара отпишу позже Заказывал здесь 1-ый раз заливал бабки без гаранта так что спокойно работайте без гаранта Спасибо еще раз продолжайте в том же духе будем работать

Leave a Reply

Your email address will not be published. Required fields are marked *

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>