Home Web Front-end HTML Tutorial High-performance WEB development image compression

High-performance WEB development image compression

Dec 16, 2016 pm 03:39 PM

1. Reduce image size

When there are many images, reducing the image size is the most direct way to increase download speed.
1. Use PNG8 instead of GIF (non-animated image), because PNG8 has the same effect, but the image size is smaller than GIF.

2. Use Fireworks to process PNG images. Many PNG images in our products are directly exported by artists using Photoshop.
Later, I asked the artist to use Fireworks to process the PNG (the approximate method is to choose to save it as PNG8 and delete the background color).
After processing, the size of the 100K image is basically reduced by 3/4, but the image quality will also be slightly reduced, it depends on whether you can accept it.

3. Use Smush.it (http://www.smushit.com/ysmush.it/) to compress images. Smush.it is an online image compression website made by the YUI team.
This website removes some metadata from the image without affecting the quality of the original image, so you can use this website for compression with confidence,
But this compression ratio is also relatively limited.


2. Merge images and split images

1. CSS Everyone knows that Sprites combine images to reduce the number of requests and improve performance. But don’t merge too many pictures. If they are too big, the display of this page will be affected by this one picture.

2. Sometimes we need to split a large picture into multiple small pictures. For example, there are few pictures on the product homepage, so there is only one large banner picture.
Since all browsers can download images concurrently, if you do not split and only use 1 large image, the download speed will be slower.


3. Transparent image processing

IE6 cannot display transparent PNG images, which is a headache for many developers. The advantages and disadvantages of several methods are introduced below.

1. Use AlphaImageLoader, IE6 supports filter, use the following CSS code to make IE6 support PNG

#some-element { 
background: url(image.png); 
_background: none; 
_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='image.png', 
sizingMethod='crop'); 
}
Copy after login

Advantages: Easy to use

Disadvantages: The performance loss is huge. AlphaImageLoader will spend a lot of resources to process transparent images. Using AlphaImageLoader, IE’s memory usage will increase rapidly.
Also, all processing of AlphaImageLoader is performed synchronously in the same thread, so when there are too many AlphaImageLoaders, it will block the rendering of the UI.
Use _filter, IE7 can also recognize it. In fact, IE7 can recognize PNG transparent images. If you use the above code under IE7, IE7 will not use the image directly, but use AlphaImageLoader.
Note: Personally, it is recommended to avoid using AlphaImageLoader as much as possible

2. JS processing
Using DD_belatedPNG (http://www.dillerdesign.com/experiment/DD_belatedPNG/), you can easily process all transparent images on the interface in the same way.
Advantages: Simple to use (simpler than AlphaImageLoader)
Disadvantages: When there are many pictures to be processed on the page, the speed is relatively slow, and the pictures cannot be changed dynamically.

3. VML
IE6 supports VML. VML can use transparent images. The code is as follows:
Modify the html code header
html xmlns ="http://www.w3.org/1999/xhtml" xmlns:v >
head >
style type ="text/css" >
v:* { behavior : url(#default#VML) ; }
span style="color: rgb(128, 0, 0);">style >
span style="color: rgb(128, 0, 0);">head >
body >
v:image src ="image.png" />
span style="color: rgb(128, 0, 0);">body >
span style="color: rgb(128, 0, 0);">html >


Advantages: good performance, fast speed
Disadvantages: It is complicated to use and does not support browsers such as Firefox. It is necessary to determine whether different browsers output different HTML codes.

4. Download pictures from multiple domain names

Because each browser can only send fixed requests to the same domain name at the same time, for example, IE6 seems to have 2 requests, so you can open multiple domain names to request image resources.
For example, img1.abc.com, img2.abc.com. But don’t open too many domain names, because it takes time to resolve domain names and open new connections. If there are too many domain names, it may be slower. Generally, 2-4 domain names are enough.

5. Caching background images under IE6

IE6 background image caching is a troublesome thing. Many people know to use the following JS to let IE6 cache background images
try{
document.execCommand("BackgroundImageCache", false, true);
}catch(e){}
But the effect of this is not very good. When the background image is changed by mouse movement, IE6 will always send an image request (even though the background image has been downloaded).
Although the return result is 304, it still takes a lot of time. In this case, you can use the following workaround:
Use a DIV element directly on the page to load the image, so that the loaded image can be truly cached, and no request will be sent when the mouse moves.

6. Preload images

Use the following code to preload the images of the next page after the page is loaded. When entering the next page, there is no need to download the images again

window.onload=function(){ 
var img = new Image(); 
img.src = "images/image.png"; 
img = null; 
};
Copy after login

The above is image compression, developed by WEB Content, please pay attention to the PHP Chinese website (www.php.cn) for more related articles!


Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Python web development framework comparison: Django vs Flask vs FastAPI Python web development framework comparison: Django vs Flask vs FastAPI Sep 28, 2023 am 09:18 AM

Python web development framework comparison: DjangovsFlaskvsFastAPI Introduction: In Python, a popular programming language, there are many excellent web development frameworks to choose from. This article will focus on comparing three popular Python web frameworks: Django, Flask and FastAPI. By comparing their features, usage scenarios and code examples, it helps readers better choose the framework that suits their project needs. 1. Django

How to use the Twig template engine in PHP for web development How to use the Twig template engine in PHP for web development Jun 25, 2023 pm 04:03 PM

With the continuous development of Web development technology, more and more developers are beginning to look for more flexible and efficient template engines to develop Web applications. Among them, Twig is a very excellent and popular PHP template engine. It is developed based on the Symfony framework and supports unlimited expansion. It is very suitable for building complex web applications. This article will introduce how to use the Twig template engine for web development in PHP. 1. Introduction to Twig template engine Twig is developed by FabienPoten

Reimagining Architecture: Using WordPress for Web Application Development Reimagining Architecture: Using WordPress for Web Application Development Sep 01, 2023 pm 08:25 PM

In this series, we will discuss how to build web applications using WordPress. Although this is not a technical series where we will look at code, we cover topics such as frameworks, fundamentals, design patterns, architecture, and more. If you haven’t read the first article in the series, I recommend it; however, for the purposes of this article, we can summarize the previous article as follows: In short, software can be built on frameworks, software can Extend the base. Simply put, we distinguish between framework and foundation—two terms that are often used interchangeably in software, even though they are not the same thing. WordPress is a foundation because it is an application in itself. It's not a framework. For this reason, when it comes to WordPress

MySQL and PostgreSQL: Best Practices in Web Development MySQL and PostgreSQL: Best Practices in Web Development Jul 14, 2023 pm 02:34 PM

MySQL and PostgreSQL: Best Practices in Web Development Introduction: In the modern world of web development, databases are an essential component. When choosing a database, common choices are MySQL and PostgreSQL. This article will cover best practices for using MySQL and PostgreSQL in web development and provide some code examples. 1. Applicable scenarios MySQL is suitable for most web applications, especially those that require high performance, scalability and ease of use.

What are the advantages and disadvantages of C++ compared to other web development languages? What are the advantages and disadvantages of C++ compared to other web development languages? Jun 03, 2024 pm 12:11 PM

The advantages of C++ in web development include speed, performance, and low-level access, while limitations include a steep learning curve and memory management requirements. When choosing a web development language, developers should consider the advantages and limitations of C++ based on application needs.

What are the common application scenarios of Golang in software development? What are the common application scenarios of Golang in software development? Dec 28, 2023 am 08:39 AM

As a development language, Golang has the characteristics of simplicity, efficiency, and strong concurrency performance, so it has a wide range of application scenarios in software development. Some common application scenarios are introduced below. Network programming Golang is excellent in network programming and is particularly suitable for building high-concurrency and high-performance servers. It provides a rich network library, and developers can easily program TCP, HTTP, WebSocket and other protocols. Golang's Goroutine mechanism allows developers to easily program

The balance of hard and soft skills required for Python developers The balance of hard and soft skills required for Python developers Sep 10, 2023 am 11:40 AM

Python is one of the most popular programming languages ​​today, attracting many developers to join the Python development field. However, to be an excellent Python developer requires not only mastering the hard skills of the programming language, but also certain soft skills. This article will explore how Python developers can strike a balance between hard and soft skills. In the world of Python development, hard skills refer to the technical and programming knowledge required by developers. The Python language itself is simple, flexible, easy to learn and use,

What skills and resources are needed to learn C++ web development? What skills and resources are needed to learn C++ web development? Jun 01, 2024 pm 05:57 PM

C++ Web development requires mastering the basics of C++ programming, network protocols, and database knowledge. Necessary resources include web frameworks such as cppcms and Pistache, database connectors such as cppdb and pqxx, and auxiliary tools such as CMake, g++, and Wireshark. By learning practical cases, such as creating a simple HTTP server, you can start your C++ Web development journey.

See all articles