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,814 thoughts on “JavaScript Image Optimiser (JSIO)

  1. РУС-МеДтеХ — официальный дистрибьютор медицинской техники и оборудования от ведущих производителей. Компания предлагает полное оснащение лечебно-профилактических учреждений: от диагностического и реанимационного оборудования до медицинской мебели и расходных материалов. На платформе https://rus-medteh.ru/ доступны запасные части, медицинская одежда и техника для домашнего использования. Каталог охватывает более 37 категорий товаров для клиник, лабораторий и частных покупателей. Здесь работают с государственными учреждениями и частными клиниками, обеспечивая выгодные цены и профессиональный сервис.

  2. Ровной работы https://catalink.ru в том то и дело что мнения в курилках а тут факты пишут все. Я думаю что есть разница между мнением и фактом. Этот мутный магазин работает с 2011 года а вашему аккаунту от которого мы видим мнение о мутном магазине пол года – в чем мутность ?ТС саппорт не требуется тебе ? Напиши в лс если интересно

  3. apartment near quarry bay mtr Buying uk property from Hong Kong luxury apartment for sale repulse bay hong kong

  4. Хороший магазинчик рега хорошая в общем стоит вашего внимания всем удачи купить закладку мефедрон кокаин скорость ОТЛИЧНЫЙ МАГАЗИН ВСЕ НА ВЫСШЕМ УРОВНЕэто манера такая сдержанная или удовлетворительное=на троечку

  5. Ищете кроссовер ex5 em i? Зайдите на geely-kuntsevo.ru/models/geely-ex5-em-i — здесь собрана исчерпывающая информация об этом кроссовере: от доступных комплектаций и технических характеристик до дизайна и условий дальнейшего обслуживания. При необходимости получите персональное предложение. У нас гарантия 5 лет, а также существенная выгода по Trade In, выгодные условия кредита. Ознакомьтесь с полными условиями на нашем сайте.

  6. 1 bedroom apartment for sale hong kong Apartment for sale central Hong Kong buying property in hong kong mortgage

  7. Настоящая русская баня немыслима без хорошего веника — и именно здесь кроется секрет истинного удовольствия от парной. Магазин «Парвеник» предлагает широкий выбор банных веников: дубовые, берёзовые, эвкалиптовые и хвойные — каждый вид обладает своими целебными свойствами и особым ароматом. На сайте https://www.parvenik.ru/ можно оформить заказ оптом и в розницу по ценам ниже рыночных, а акция «5+1 в подарок» даёт реальную скидку в 20%. Доставка осуществляется курьером в пределах МКАД и через удобные пункты выдачи Яндекс Маркета по всему Подмосковью. Товар отличается отборным качеством — и в этом легко убедиться лично, забрав заказ в основном пункте выдачи на улице Молодцова, 29.

  8. Да и вообще стот ли…? риск есть…? https://ikea-bathroom.ru упаковка – неплохо но не идеально. Особенно глупо когда в описании отправления пишут Косметика а там блть пачка сигарет. Оочень странно на меня смотрели в офисе спсра знаете ли. 4/5явно не 15-ти минутка почитайте отзывы в соответвующей теме. Качество товара на высоте у нас всегда .

  9. «Онис» — московская клиника с узкой специализацией на варикозе и сосудистых патологиях с использованием современных малоинвазивных методов. В арсенале врачей — лазерная коагуляция, склеротерапия и радиочастотная абляция без разрезов и продолжительного периода восстановления. Подробнее об услугах и специалистах — https://www.onisclinic.ru/ — платформа с полной информацией о методах лечения и записи на приём. После диагностики каждому пациенту составляют индивидуальный план лечения, а стойкий эффект достигается за счёт точного подхода и высокой квалификации специалистов.

  10. buy apartment near wan chai mtr Buying property in Hong Kong down payment buy flat in wan chai hong kong

  11. กำลังมองหาข้อมูลเกี่ยวกับหัวข้อนี้อยู่ใช่ไหม? เข้าชมเว็บไซต์ https://seidentest.com/ คุณจะพบคำตอบสำหรับคำถามนี้และคำถามอื่นๆ อีกมากมายที่คุณอาจมี เรียนรู้เพิ่มเติมได้ที่เว็บไซต์

  12. А какой ты адрес хотел что бы тебе написали если ты заказываешь может ты данные свои для отправки до сих пор не указал и в ожидании чуда сидишь купить закладку мефедрон кокаин скорость Заказал вчера 30гр 4-FA . Трек пока не получил. Надеюсь что все будет олрайт. В планах долговременное сотрудничествоМне от оплаты и в мои руки в общем занимает 2-3 дня

  13. https://onlinecasino-square.com/ にアクセスしてください。そこでは、信頼できる情報源から得た、日本の様々なカジノに関する包括的な情報をご覧いただけます。ゲームプラットフォームの独立した評価や、登録ボーナス、常連プレイヤー向けボーナスに関する重要な情報も掲載されています。詳しくはウェブサイトをご覧ください。

  14. central hong kong apartments for sale Hong kong flats for sale buy apartment kowloon tong hong kong

  15. Игорь Павлышен https://pavlyshen.ru/ — профессиональный интернет-маркетолог с практикой свыше 8 лет. В перечень услуг входят: настройка и ведение Яндекс.Директ, SEO-оптимизация сайтов и внедрение CRM-решений. Сертифицированный специалист Яндекс. Сотрудничаю с компаниями и предпринимателями из любых регионов России. Обеспечиваю рост продаж клиентов с помощью точечной интернет-рекламы и грамотного SEO.

  16. Всё отлично 5 из 5. Только сделайте больше районов в Питере. https://ikea-bathroom.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>