HTML optimization techniques you must know

HTML optimization techniques you must know

To improve the performance of web pages, many developers start from multiple aspects such as JavaScript, image optimization, server configuration, file compression or adjusting CSS.

It's clear that HTML has reached a bottleneck, even though it is the core language required to develop Web interfaces. The load of HTML pages is also getting heavier. Most pages require an average of 40K of space. Some large websites may contain thousands of HTML elements, so the page size will be larger.

How to effectively reduce the complexity of HTML code and the number of page elements? This article mainly solves this problem and introduces from multiple aspects how to write concise and clear HTML code, which can make the page load faster and run well on multiple devices.

The following principles need to be followed during the design and development process:

  • Structural separation: Use HTML to add structure, not style content;
    Keep it clean: Add code validation tools to your workflow; use tools or style guides to maintain code structure and format. Learn a new language: Get the element structure and semantic markup right.
    Ensure accessibility: Use ARIA attributes and Fallback attributes, etc. Test: Make the website run well on multiple devices, use emulators and performance tools.

The relationship between HTML, CSS and JavaScript

HTML is a markup language used to coordinate the structure and content of web pages. HTML cannot be used to modify style content, nor can text content be entered in the head tag, which makes the code lengthy and complicated. Instead, it is more appropriate to use CSS to modify layout elements and appearance. The default appearance of HTML elements is defined by the browser's default style sheet. For example, in Chrome, the h1 tag element will be rendered as 32px Times bold.

Three general design rules:

  • Use HTML to construct the page structure, CSS to modify the page presentation, and JavaScript to implement page functions. CSS ZenGarden is a great example of behavior separation.
    Use less HTML code if you can use CSS or JavaScript to achieve it.
    Store CSS and JavaScript files separately from HTML. This can help with caching and debugging.

The document structure can also be optimized as follows:

1. Use HTML5 document type. The following is an empty file:

XML/HTML CodeCopy content to clipboard
  1. <!DOCTYPE html >   
  2. < html >   
  3.   
  4. < head >   
  5.   < title > Recipes: pesto </ title >   
  6. </ head >   
  7.   
  8. < body >   
  9.   
  10.    < h1 > Pesto </ h1 >   
  11.   
  12.    < p > Pesto is good! </ p >   
  13.   
  14. </ body >   
  15. </ html >   
  16.   

2. Reference the CSS file at the beginning of the document as follows:

XML/HTML CodeCopy content to clipboard
  1. < head >   
  2.    < title > My pesto recipe </ title >   
  3.   
  4.    < link   rel = "stylesheet"   href = "/css/global.css" >   
  5.    < link   rel = "stylesheet"   href = "css/local.css" >   
  6.   
  7. </ head >   
  8.   

With both methods, the browser will prepare the CSS information before parsing the HTML code. Therefore, it helps improve page loading performance.

Entering JavaScript code before the body closing tag at the bottom of the page will help speed up page loading because the browser will load the page before parsing the JavaScript code. Using JavaScript will have a positive impact on page elements.

XML/HTML CodeCopy content to clipboard
  1. < body >   
  2.   
  3. ...
  4.   
  5.    < script   src = "/js/global.js" >   
  6.    < script   src = "js/local.js" >   
  7.   
  8. </ body >   
  9.   

Using the Defer and async attributes, script elements with the async attribute are not guaranteed to be executed in order.

Handlers can be added in JavaScript code. Never add it to HTML inline code, such as the following code, which is prone to errors and difficult to maintain:

index.html:

XML/HTML CodeCopy content to clipboard
  1. < head >   
  2.      
  3. ...
  4.   
  5.    < script   src = "js/local.js" >   
  6.   
  7. </ head >   
  8.   
  9. < body   onload = "init()" >   
  10.   
  11. ...
  12.   
  13.    < button   onclick = "handleFoo()" > Foo </ button >   
  14.   
  15. ...
  16.   
  17. </ body >   
  18.   

The following is better:

index.html:

XML/HTML CodeCopy content to clipboard
  1. < head >   
  2.   
  3. ...
  4.   
  5. </ head >   
  6.   
  7. < body >   
  8.   
  9. ...
  10.   
  11.    < button   id = "foo" > Foo </ button >   
  12.   
  13. ...
  14.   
  15.    < script   src = "js/local.js" >   
  16.   
  17. </ body >   
  18.   

js/local.js:

JavaScript CodeCopy content to clipboard
  1. init();
  2. var fooButton =
  3. document.querySelector( '#foo' );
  4. fooButton.onclick = handleFoo();

verify

One way to optimize web pages is to enable browsers to handle illegal HTML code. Legal HTML code is easy to debug, takes up less memory, consumes less resources, is easy to parse and render, and runs faster. Illegal HTML code makes it extremely difficult to implement responsive design.

When using templates, legal HTML code is extremely important. It often happens that a template runs well alone, but when integrated with other modules, various errors are reported. Therefore, the quality of HTML code must be guaranteed. The following measures can be taken:

  • Add validation to your workflow: Use validation plugins like HTMLHint or SublineLinter to help you detect coding errors.
    Use the HTML5 document type to ensure that the HTML hierarchy is easy to maintain and avoid element nesting in the left-open state.
    Make sure to add the closing tag for each element.
    Delete unnecessary code; there is no need to add end tags for self-closing elements; Boolean attributes do not need to be assigned values, if they exist, they are True;

Code format

Format consistency makes HTML code easy to read, understand, optimize, and debug.

Semantic markup

Semantics refers to things that are related in meaning, and HTML can be seen in the semantics of the page content: the naming of elements and attributes to some extent expresses the role and function of the content. HTML5 introduces new semantic elements such as <header>, <footer>, and <nav>.

Choosing the right elements to write your code ensures that it is easy to read:

  • Use <h1> (<h2>, <h3>…) to indicate a title, and <ul> or <ol> to implement a list;
    Note that the <h1> tag should be added before using the <article> tag;
    Choose appropriate HTML5 semantic elements such as <header>, <footer>, <nav>, <aside>;
    Use <p> to describe the body text. HTML5 semantic elements can form content, but the reverse is not true.
    Use <em> and <strong> tags instead of <i> and <b> tags.
    Use the <label> element, input type, placeholder, and other attributes to enforce validation.
    Mixing text with elements as children of another element can lead to layout errors.

For example:

XML/HTML CodeCopy content to clipboard
  1. < div > Name: < input   type = "text"   id = "name" > </ div >   

It would be better to write it another way:

1: <div>
2: <label for="name">Name:</label><input type="text" id="name">
3: </div>

layout

To improve the performance of HTML code, follow the principle that HTML code should be designed for functionality rather than style.

  • Use the <p> element to decorate text, not layout; by default, <p> automatically provides margins, and other styles are also provided by the browser by default.
    Avoid using <br> to break lines. Use block elements or CSS display properties instead.
    Avoid using <hr> to add horizontal rules. Use CSS border-bottom instead.
    Don't use div tags unless it's a critical moment.
    Try to use as few tables as possible for layout.
    You can use Flex Box more
    Use CSS to adjust margins etc.

CSS

Although this article is about optimizing HTML, here are some basic skills for using CSS:

  • Avoid inline CSS
    Use the ID class at most once. When multiple elements are involved, you can use Class to implement it.

The above are the tips for optimizing HTML code introduced in this article. A high-quality and high-performance website often depends on the handling of details.

<<:  How to remove the dotted border when clicking a link in FireFox

>>:  How to use the VS2022 remote debugging tool

Recommend

JavaScript to achieve Taobao product image switching effect

JavaScript clothing album switching effect (simil...

Implementation of scheduled backup in Mysql5.7

1. Find mysqldump.exe in the MySQL installation p...

Detailed example of clearing tablespace fragmentation in MySQL

Detailed example of clearing tablespace fragmenta...

How to use Nexus to add jar packages to private servers

Why do we need to build a nexus private server? T...

Detailed explanation of vue simple notepad development

This article example shares the specific code of ...

MySQL8.0.18 configuration of multiple masters and one slave

Table of contents 1. Realistic Background 2. Agre...

Analysis of the principles and usage of Docker container data volumes

What is a container data volume If the data is in...

How to add indexes to MySQL

Here is a brief introduction to indexes: The purp...

Common properties of frameset (dividing frames and windows)

A frame is a web page screen divided into several ...

Mini Program Recording Function Implementation

Preface In the process of developing a mini progr...

MySQL query optimization using custom variables

Table of contents Optimizing sorting queries Avoi...

How to maintain a long connection when using nginx reverse proxy

· 【Scene description】 After HTTP1.1, the HTTP pro...