Lessons
-
Introduction
-
SEO
- Broken links
- Site map
- Semantic markup
- Robots.txt
- References
- Text
- Duplicates
- Basic
- Pictures
-
Speed
-
Minification
-
Minification of CSS to reduce its volume
Minification of the embedded JavaScript code of the page
Minification of the embedded CSS code of the page
Minification of images without loss of quality
Minification of JavaScript files to reduce its volume
Unused CSS code
Data optimization:Image URLs
Animated image format MP4, WEBM, SVG instead of GIF and WEBP
Unused JavaScript code
Using the WebP format in images
Too high-quality images without using compression
Suitable video bitrate
-
Reducing requests
-
An overabundance of small pictures
Grouping CSS files
Grouping JavaScript files
An overabundance of font files
Availability of end-to-end CSS, JS files
The presence of a monochrome font
Uploading duplicate files
Using JavaScript facades
Redirecting JavaScript code
Adding lazy loading
Redirect from/to www version
-
Fonts
-
Specifying default fonts
Font Optimization
An overabundance of monochrome icons
- Loading time
- Server Settings
- Pictures
-
The first content
-
The sequence of connecting JavaScript files
Font display mode
Setting up a pre-connection
Removing lazy loading
Long JavaScript code execution time
File upload delayed or on demand
The server is located in the same country where the users of the site live
No requests to another country that cause page loading to be blocked
-
Minification
-
Mobility
-
Screen support
-
Adapting the layout to a Full HD computer monitor
Adapting the layout for a horizontal tablet
Adapting the layout for a horizontal phone
Screenshots for the mini-report
How blocks break the page layout
Adapting the layout to an HD computer monitor
Adapting the layout for a vertical tablet
Adapting the layout for a vertical phone
- Comfort
-
Screen support
- Bugs
-
Convenience
- Social networks
- Web Application Manifest
- Favicons
- Basic
- Text readability
-
Vulnerabilities
- Encrypted connection
- Exploits
- Vulnerabilities
Font Optimization
Font files contain a vector description of each character and metadata. They also often contain various subtle visual settings.
That’s how fine-tuning affects font displays. All these settings are needed for designers, not for websites.
To optimize the font, you need to:
- Leave only the letters of the alphabet used on the site in the file. The font can contain more than 10 languages, but 2 will be enough for you: the language of your site and the English alphabet to display foreign names of sites, brands, and other things.
- Remove extra characters. For example, fractions, complex mathematical signs and other rarely used symbols.
- Remove all the fine-tuning embedded in the font by its author. They can’t be used on the site anyway.
- Use the woff2 format.
You can do all this in our service.
Useful materials:
- You can find out how the fine-tuning of font files works and what is affected in the service [https://fontdrop.info /](https://fontdrop.info /).
- A complete list of similar settings described here.
- Our article on font optimization.
Below is an example of how many unused characters the standard Roboto Regular font file contains:
Demonstration
PHP code
<?php
// Получаем список глифов, доступных в файле
$data = exec("fc-query --format='%{charset}\\n' Roboto-Regular.ttf", $output);
$data = array_pop($output);
$data = explode(' ', $data);
$glyphs = [];
foreach($data as $range) {
$range = explode('-', $range);
$range[1] = hexdec($range[1] ?? $range[0]);
$range[0] = hexdec($range[0]);
for($i = $range[0]; $i <= $range[1]; $i++) {
$glyphs[] = $i;
}
}
?><!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
@font-face {
font-family: 'Roboto';
src: url('./Roboto-Regular.ttf') format('truetype');
font-style: normal;
font-weight: 400;
}
body {
font-family: Roboto;
}
div {
border: 1px solid #000;
margin: 2px;
padding: 3px;
border-radius: 3px;
display: inline-block;
min-width: 20px;
text-align: center;
}
</style>
</head>
<body>
<h1>В шрифте Roboto.ttf <?=sizeof($glyphs)?> символов. Обычно используется не более 120.</h1>
<?php foreach($glyphs as $glyph) { ?>
<div>&#<?=$glyph?>;</div>
<?php } ?>
</body>
</html>