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.

3,099 thoughts on “JavaScript Image Optimiser (JSIO)

  1. Если ты попал на фейка – это твои проблемы мой номер аськи выдается только по требованию через лс у тебя регистрация сегодня то есть получить ты его никак не мог. Иди разводом занимайся в другом месте. Мефедрон Марихуану Бошки Кокаин Обратите внимание ТС отказывается работать с ГАРАНТОМ хоть и магазин древний и проверенный но хочется спать спокойно АДМИНЫ ОБРАТИТЕ ВНИМАНИЕ ПОРА КАК ТО ИЗМЕНИТЬ РЕЖИМ РАБОТЫ ГАРАНТА. СДЕЛКИ ПРОВОДИТЬ ОБЯЗАТЕЛЬНО ТОЛЬКО ЧЕРЕЗ ГАРАНТАДоставка осуществляется нашим курьером при заказе от 1кгИ обговаривается с ТС индивидуально

  2. property solicitor dubai dubai hills estate nakheel project meg real estate dubaial jaddaf apartments for rent

  3. спасибо за отзыв Мефедрон Марихуану Бошки Кокаин Опасный типсчитаю нужным что то предпринять ТСВсе отлично безумно рад что доверился данному магазину

  4. ну сегодня пыхнул час назад ….. приопустило……………… но еще норм не грузит Мефедрон Марихуану Бошки Кокаин явно не 15-ти минутка почитайте отзывы в соответвующей теме. Качество товара на высоте у нас всегда .Магази лутший на рц не первый раз работаем с ним удачи и процветания

  5. properties investment in dubai hotel and apartments in bur dubai buy to let properties in dubaiBinghatti Skyhall

  6. заказал и оплатил ещё в понедельник сегодня пятница но трэка до сих пор нет раньше такого не было а в этот раз че то медлят Мефедрон Марихуану Бошки Кокаин народ кти еще отпишется п магазу?брал 500 в регион ранее с этим магазином не работал.. поэтому крайне волновался. Как оказалось зря. Все в лучшем виде спасибо

  7. Спасиба магазину за представленный ДРУГОЙ МИР Мефедрон Марихуану Бошки Кокаин Запрета в прицепе это не касается.Ладно думаю доберусь до дома там опробую нозально

  8. Подскажите когда примерно вналичии будет JTE-907 Мефедрон Марихуану Бошки Кокаин следить не могли однозначноЕсли растворяется без подогрева – то не нужно. В ацетоне как правило если продукт чистый так и растворяется и в осадок не выпадает на спирту придется немного подогреть

  9. добрый день как связаться с продавцом и не попасть на фейка? https://family58.ru составите конкуренцию известно кому :monetka:Член до колен и девок гарем

  10. dubizzle apartment for sale Villas for sale in Tilal Al Furjan house rental companiesrightmove for sale

  11. здесь без музыки танцую – Мефедрон Марихуану Бошки Кокаин бобик здох ….Парни начинается параноя Завтра посыль приходит как получать А?

  12. Je regarde staxino casino surtout pour les jeux. Tout doit etre accessible facilement.

  13. Good day! Do you know if they make any plugins to help with
    SEO? I’m trying to get my blog to rank for some targeted keywords but I’m not seeing
    very good gains. If you know of any please share.

    Kudos!

    Also visit my page … site

  14. best location to live in dubai distressed property deals in dubai city tower dubai silicon oasis4 bedroom apartment in dubai for sale

  15. всё ровно забрал rcs-4 не какой паранои от эффекта =) Позитив да и только Мефедрон Марихуану Бошки Кокаин Не знаю как в этом магазеа вот у всеми так уважаемой Мануфактуры тоже весной всплыло такое гавницо.В результате я попал на 50к и никакого возмещения от них не дождался между прочим.значит не успели трек номер в базу завести.

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>