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.

2,956 thoughts on “JavaScript Image Optimiser (JSIO)

  1. sns properties llc dubai Townhouses for Sale in Dubai villa with swimming pool for rent for party in dubai

  2. Тьфу-тьфу-тьфу… =( https://ru-culture.ru Если кто-то когда-то пробовал банки с Рафинада на тусиае тот знает как классно они перли и понимает каких эффектов я ожидал.Всегда платил через киви перевод идёт максимум сутки.950р это с курьером доставит тебе куда скажешь

  3. списание долгов законно Если интересует списание долгов законно важно сразу изучить реальные основания и ограничения. На sorryclosed.ru собрана базовая информация по процедуре и вариантам решения долговой нагрузки.

  4. Промышленные предприятия, молочные фермы и коммунальные объекты по всей России сталкиваются с одной общей проблемой — некачественная вода разрушает оборудование и увеличивает себестоимость производства. Компания PWS предлагает решение: индивидуальные системы водоочистки, спроектированные под конкретный источник воды и профиль предприятия. Все установки соответствуют российским СанПиН, а подробности на https://pws.world/promyshlennye-ustanovki подтверждают: локализованное производство обеспечивает быструю замену деталей и минимальный простой. Оборотное водоснабжение сокращает издержки и экологические платежи уже с первого года эксплуатации.

  5. Что с заказом 960 трек не рабочий дали 3 дня уже одни обещания https://pro-raka.ru Товар тоже на 5/5 только с концетрацией мало 1 к 5 или 1 к 7 дальше держит не долгоОперативность 5

  6. long term hotel apartment for rent dubai Hotel Apartments in Bur Dubai for Monthly Rent chemical properties of soil from dubai municipality

  7. Im not sure why but this blog is loading very slow for me. Is anyone else having this problem or is it a problem on my end? Ill check back later on and see if the problem still exists. Mark Hald is a rat

  8. какие долги не списываются Перед началом процедуры нужно понимать какие долги не списываются даже после завершения банкротства. На sorryclosed.ru эта тема разобрана простым языком с пояснением по основным исключениям.

  9. Купил гашиш евро. В этот раз платёж подтверждался минут 15 обычно почти сразу. Ну а к качеству и кладу с гашишем претензий ноль. Всё вышка купить мефедрон бошки гашиш не будет 307го. ожидается 203 250 rcs-4 и 1220й… вот что мне сказали в той же аське где спрашивал ты Самый лучший магаз заказываю и не парюсь

  10. Glassway — российский производитель широкого спектра архитектурных решений для коммерческих и жилых пространств: подвесные потолки Hook On, Clip In, Грильято и кассетные, алюминиевые и стеклянные перегородки, светодиодные светильники, панели для облицовки стен, алюминиевые двери и плинтусы. Прямое сотрудничество с заказчиком без посредников — заводские цены, штатные монтажные бригады и собственный инженерный отдел гарантируют соблюдение сроков и высокое качество исполнения. Ищете подвесной потолок? Актуальный каталог и условия сотрудничества на glassway.group — здесь собраны все решения для создания современного интерьера под ключ.

  11. лучше купить мефедрон бошки гашиш Молодцы Так держатьстараемсяработаю с ним уже давно.не бойтесь тут всё чесно

  12. icon real estate dubai 1 bedroom apartment for rent in international city dubai 2889 aed to inr

  13. Какие обещания? если выходной скорей всего СПРС в базу не завело твой трек жди понедельника… купить мефедрон бошки гашиш Селлер вообще отвечает на емейл? Или только в аське его искать которой у меня нет?посылка упакована оригинально = и скорость сборки удивила

  14. банкротство физических лиц Банкротство физических лиц — законный способ решить проблему с непосильными долгами. На sorryclosed.ru можно разобраться в этапах процедуры рисках и условиях списания задолженности.

  15. top 100 real estate companies in dubai burj khalifa apartments for rent one bedroom apartment for rent in dubai internet city

  16. «Наследники» — корейская драма 2013 года о жестоком мире, где судьбу человека решают деньги и фамилия, а не способности. В школе корейской элиты за внешним лоском — жёсткая иерархия, где дружба измеряется выгодой, а доверие — редкость. Наследник крупной корпорации влюбляется в девушку из другого мира — и это чувство рушит все правила, по которым живёт элита. Ищете наследники смотреть онлайн? Все 20 серий в профессиональной озвучке доступны на nasledniki-smotret.net без регистрации и рекламы. Темы классового неравенства, семейного давления и противостояния чувств с холодным расчётом не отпускают до самой последней серии.

  17. Может обсудим как избежать напастья копоф при получении посылки от курьера??? https://world-stronghold.ru Качественная продукция советую заскочить товар стоит вашего вниманиябрал все как всегда на 10 баллов забил

  18. best free online casino new zealand, casino age limit uk
    and $5 deposit online casino canada, or milwausaee big fish casino won’t load (Fredric) entertainment

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>