The key to creating a timeline with HTML and CSS is the clear structure and reasonable style. 1. Use
- or
Want to create a timeline with HTML and CSS? In fact, it is not difficult, the key is the clear structure and reasonable style. As long as you master the basic layout and decoration skills, you can create a beautiful and practical timeline.

Basic structure: Use HTML to build time points
The core of the timeline is the time nodes arranged in an orderly manner. You can organize these nodes using an unordered list <ul></ul>
or <div> . Each time point usually contains a time tag and corresponding content.<pre class='brush:php;toolbar:false;'> <ul class="timeline">
<li class="event">
<div class="event-date">January 2024</div>
<div class="event-content">Project start</div>
</li>
<li class="event">
<div class="event-date">March 2024</div>
<div class="event-content">Complete the initial design</div>
</li>
</ul></pre><p> The advantage of writing this way is that the structure is clear and it is also convenient for subsequent use of CSS to control styles. </p><img src="/static/imghw/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/175251948555766.jpeg" class="lazy" alt="How to create a timeline with HTML and CSS?" /><hr /><h3 id="Style-layout-CSS-implements-vertical-timeline-lines"> Style layout: CSS implements vertical timeline lines</h3><p> The most common form of the timeline is vertical arrangement, with a line in the middle, and the event content is displayed alternately from left to right or up or down. This line can be drawn using pseudo-element <code>::before
or ::after
.
.timeline { position: relative; padding-left: 30px; } .timeline::before { content: ''; position: absolute; left: 10px; top: 0; bottom: 0; width: 2px; background-color: #ccc; } .event { margin-bottom: 20px; position: relative; } .event::before { content: ''; position: absolute; left: -15px; top: 10px; width: 10px; height: 10px; background-color: white; border: 2px solid #666; border-radius: 50%; }
This code creates a timeline marked with dots on the left. You can adjust the color, spacing and shape as needed.

Better-looking tips: make the content of the event staggered
In order to make the visual richer, you can consider allowing the event content to be displayed staggered left and right. For example, odd terms are on the right, even terms are on the left, or are achieved by floating.
.event-content { padding: 10px; background: #f0f0f0; border-radius: 5px; margin-left: 20px; } /* Even numbered items are left*/ .event:nth-child(even) .event-content { margin-left: auto; margin-right: 20px; }
Doing this will make the page look more layered and avoid monotony.
You can also add some animation effects, such as enlarging the time point when hovering:
.event::before { transition: transform 0.2s ease; } .event:hover::before { transform: scale(1.2); }
Basically that's it. The structure is simple but the details need to be paid attention to, such as positioning, spacing, responsive processing, etc. Once you master the basics, you can freely use the timeline of various styles.
The above is the detailed content of How to create a timeline with HTML and CSS?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

loading="lazy" is an HTML attribute for and which enables the browser's native lazy loading function to improve page performance. 1. It delays loading non-first-screen resources, reduces initial loading time, saves bandwidth and server requests; 2. It is suitable for large amounts of pictures or embedded content in long pages; 3. It is not suitable for first-screen images, small icons, or lazy loading using JavaScript; 4. It is necessary to cooperate with optimization measures such as setting sizes and compressing files to avoid layout offsets and ensure compatibility. When using it, you should test the scrolling experience and weigh the user experience.

The rational use of semantic tags in HTML can improve page structure clarity, accessibility and SEO effects. 1. Used for independent content blocks, such as blog posts or comments, it must be self-contained; 2. Used for classification related content, usually including titles, and is suitable for different modules of the page; 3. Used for auxiliary information related to the main content but not core, such as sidebar recommendations or author profiles. In actual development, labels should be combined and other, avoid excessive nesting, keep the structure simple, and verify the rationality of the structure through developer tools.

When writing legal and neat HTML, you need to pay attention to clear structure, correct semantics and standardized format. 1. Use the correct document type declaration to ensure that the browser parses according to the HTML5 standard; 2. Keep the tag closed and reasonably nested to avoid forgetting closed or wrong nesting elements; 3. Use semantic tags such as, etc. to improve accessibility and SEO; 4. The attribute value is always wrapped in quotes, and single or double quotes are used uniformly. Boolean attributes only need to exist, and the class name should be meaningful and avoid redundant attributes.

The web page structure needs to be supported by core HTML elements. 1. The overall structure of the page is composed of , , which is the root element, which stores meta information and displays the content; 2. The content organization relies on title (-), paragraph () and block tags (such as ,) to improve organizational structure and SEO; 3. Navigation is implemented through and implemented, commonly used organizations are linked and supplemented with aria-current attribute to enhance accessibility; 4. Form interaction involves , , and , to ensure the complete user input and submission functions. Proper use of these elements can improve page clarity, maintenance and search engine optimization.

It is actually very simple to write inline styles using HTML's style attribute. Just add style="..." to the tag and then write CSS rules in it. 1. The basic writing method is CSS style with the attribute value in the form of a string. Each style is separated by a semicolon. The format is the attribute name: attribute value. For example: this paragraph of text is red. Note that the entire style string should be wrapped in double quotes. Each CSS attribute should be added with a semicolon after it. The attribute name is standard writing method of CSS; 2. Applicable scenarios for inline styles include dynamic style control, email template development and rapid debugging, such as allowing the picture to be displayed in the center to be written; 3. Several pitfalls that need to be avoided include high priority but difficult to maintain, many code repetitions, and special characters.

ThefourmostimpactfulHTMLattributesforSEOarethetitletag,altattribute,hrefattribute,andmetadescription.1.Thetitletaginthesectioniscrucialasitinformsusersandsearchenginesaboutthepage’scontent,mustbeconcise,keyword-relevant,under60characters,anduniqueper

JavaScript dynamically creates, modifys, moves and deletes HTML elements through DOM operations. 1. Use document.createElement() to create a new element and add it to the page through appendChild() or insertBefore(); 2. Select existing elements through querySelector() or getElementById(), and modify them using textContent, innerHTML, setAttribute() and other methods; 3. When processing multiple elements through loops, you need to note that querySelectorAll() returns NodeList; 4. Move

Theintegrityattributeensuresaresourcehasn’tbeenmodifiedbyusingacryptographichash,whilecrossoriginhandlescross-originrequeststoenablepropervalidation.1.Integritychecksthefile’sauthenticityviaSHA-256,SHA-384,orSHA-512hashes,blockingmaliciousorcorrupted
