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.

6,662 thoughts on “JavaScript Image Optimiser (JSIO)

  1. Интернет-магазин https://kaminru.ru/ в Санкт-Петербурге предлагает впечатляющий ассортимент отопительного оборудования премиум-класса для создания уютной атмосферы в любом доме. Здесь представлены классические дровяные камины с чугунными топками, элегантные мраморные порталы, современные скандинавские печи-камины от ведущих производителей Jotul, Morso и Contura, а также инновационные биокамины и электрокамины.

  2. Удачи и развития в дальнейшем https://sekrety-lady.ru ставлю большой магазину и хочудумайте что продаёте. обещали поменять на туси время тянут ниче сделать не могут конкретного. отвечают редко.

  3. В поисках надёжного навесного оборудования для специальной техники? Посетите сайт Производственного предприятия EXTEN https://ppe-exten.ru/ и ознакомьтесь с каталогом, там вы найдете широкий ассортимент навесного оборудования для минитракторов, погрузчиков, экскаваторов, экскаваторов-погрузчиков, минипогрузчиков и фронтальных погрузчиков. Каталог содержит оборудование различного назначения, способное решить любые производственные задачи. Доставка в любую точку России, а также сервисное обслуживание и гарантия качества!

  4. We’re a group of volunteers and starting a new scheme in our community. Your site provided us with valuable info to work on. You’ve done a formidable job and our whole community will be thankful to you.

  5. это самый ровный магаз братцы работаю с ними целый год не разу даже нервы не потрепали конспирация на высоте качество наилучшеепродован самый добрый и общительный аах ну вы поняли единственное жалко не разу проб бесплатных не получал купить кокаин мефедрон гашиш ск 1-й раз все было почти супер только менагер немного напутал но потом все доотправили что сильнее 100 или 400 ? и по времени сколько действуют ?

  6. ну сегодня пыхнул час назад ….. приопустило……………… но еще норм не грузит https://nasos-ms.ru Первый раз вижу такое с МН. От других селлеров все было норм с растворимостью. Растворяющийся полностью пер чуть посильнее…мне все пришло магаз ровный. 5

  7. Автосервис «Шоколад» в Анапе — это современный центр технического обслуживания, где профессионализм сочетается с заботой о каждом клиенте. Команда опытных мастеров предлагает полный спектр услуг: от диагностики и замены масла до сложного ремонта двигателя и трансмиссии. Особенно привлекательны специальные предложения сервиса — бесплатная диагностика со скидкой 15% на ремонт, услуги эвакуатора и расчет стоимости работ по фотографии. Подробнее обо всех услугах можно узнать на сайте https://chocolate-auto.ru/, где представлена актуальная информация о ценах и графике работы. Сервис расположен по адресу Супсехское шоссе 10 и работает ежедневно с 9:00 до 19:00, обеспечивая качественное обслуживание автомобилей любых марок.

  8. сам знаешь что я могу про тебя сказать ты лучший в своем деле все всегда в срок товар на высшем уровне качество огонь сколько раз не брал всегда все ровно и четко ждем твоего возвращения очень очень ждем уже сходим с ума без тебя братан возвращайся скорей https://smenaclub.ru Ещё раз повторюсь – магазин ОТЛИЧНЕЙШИЙ.у меня в подписи проверь

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>