Scroll down to see the fixed header in action.<\/p>\n \n <\/main>\n<\/body>\n<\/html><\/pre>
That's it. The header stays in place, and the content scrolls underneath it. Just make sure to:<\/p>\n
- \n
- Set
z-index<\/code> so the header doesn't get covered by other elements.<\/li>\n
- Match the
padding-top<\/code> of the content to the header's height.<\/li>\n
- Use
box-sizing: border-box<\/code> if your header has padding or borders.<\/li>\n<\/ul>\n
Basically, it's simple with CSS, but easy to overlook the layout shift if you don't compensatesate for the removed header flow.<\/p>"}
亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱
Use the position: fixed attribute of CSS to create a fixed header. 1. Set position: fixed, top: 0, left: 0 and width: 100% for the header to fix it on the top of the window; 2. Set z-index: 1000 to ensure that the header is above other content; 3. Add padding-top to the main content area, the value is equal to the header height to prevent the content from suddenly moving up due to the header's escape from the document flow; 4. Optionally use box-shadow and box-sizing: border-box in the header to optimize vision and layout; finally, the header is always topped and the content scrolls normally.
To create a fixed header that stays at the top of the page when scrolling, you can use pure CSS with the
position: fixed
property. This is a common UI pattern that improves navigation on long web pages.Use
position: fixed
for the headerThe key is to apply
position: fixed
to your header element and set its width to span the full top of the viewport.header { position: fixed; top: 0; left: 0; width: 100%; background-color: white; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); z-index: 1000; /* Ensures the header stays above other content */ }
This will "lock" the header at the top of the viewport, even as the user scrolls down the page.
Account for content jumping
When you use
position: fixed
, the header is removed from the normal document flow. This can cause the main content to jump up, as if the header suddenly disappeared.To prevent this, add padding or margin to the top of the main content equal to the height of the header.
main { padding-top: 80px; /* Adjust this value to match your header's height */ }
Alternatively, you can wrap your content in a container and apply the padding to that.
Optional: Add smooth appearance effects
You can enhance the fixed header with subtle transitions or hide it on scroll down and show on scroll up using JavaScript, but for a basic CSS-only version, the above is sufficient.
Full minimum example
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <title>Fixed Header Example</title> <style> body { margin: 0; font-family: Arial, sans-serif; } header { position: fixed; top: 0; left: 0; width: 100%; height: 60px; background: #ffff; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); z-index: 1000; display: flex; align-items: center; padding: 0 20px; box-sizing: border-box; } main { padding-top: 60px; /* Same as header height */ min-height: 2000px; /* For scroll demo */ } </style> </head> <body> <header> <h1>My Fixed Header</h1> </header> <main> <p>Scroll down to see the fixed header in action.</p> <!-- Add more content to enable scrolling --> </main> </body> </html>
That's it. The header stays in place, and the content scrolls underneath it. Just make sure to:
- Set
z-index
so the header doesn't get covered by other elements. - Match the
padding-top
of the content to the header's height. - Use
box-sizing: border-box
if your header has padding or borders.
Basically, it's simple with CSS, but easy to overlook the layout shift if you don't compensatesate for the removed header flow.
The above is the detailed content of How to create a fixed header on scroll with CSS?. For more information, please follow other related articles on the PHP Chinese website!
Statement of this WebsiteThe 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.cnHot 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
Grass Wonder Build Guide | Uma Musume Pretty Derby3 weeks ago By Jack chenRoblox: 99 Nights In The Forest - All Badges And How To Unlock Them3 weeks ago By DDDUma Musume Pretty Derby Banner Schedule (July 2025)4 weeks ago By Jack chenToday's Connections hint and answer 3rd July for 7531 months ago By Jack chenWindows Security is blank or not showing options4 weeks ago By 下次還敢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)
CSS tutorial for creating loading spinners and animations Jul 07, 2025 am 12:07 AM
There are three ways to create a CSS loading rotator: 1. Use the basic rotator of borders to achieve simple animation through HTML and CSS; 2. Use a custom rotator of multiple points to achieve the jump effect through different delay times; 3. Add a rotator in the button and switch classes through JavaScript to display the loading status. Each approach emphasizes the importance of design details such as color, size, accessibility and performance optimization to enhance the user experience.
Addressing CSS Browser Compatibility issues and prefixes Jul 07, 2025 am 01:44 AM
To deal with CSS browser compatibility and prefix issues, you need to understand the differences in browser support and use vendor prefixes reasonably. 1. Understand common problems such as Flexbox and Grid support, position:sticky invalid, and animation performance is different; 2. Check CanIuse confirmation feature support status; 3. Correctly use -webkit-, -moz-, -ms-, -o- and other manufacturer prefixes; 4. It is recommended to use Autoprefixer to automatically add prefixes; 5. Install PostCSS and configure browserslist to specify the target browser; 6. Automatically handle compatibility during construction; 7. Modernizr detection features can be used for old projects; 8. No need to pursue consistency of all browsers,
What is the difference between display: inline, display: block, and display: inline-block? Jul 11, 2025 am 03:25 AM
Themaindifferencesbetweendisplay:inline,block,andinline-blockinHTML/CSSarelayoutbehavior,spaceusage,andstylingcontrol.1.Inlineelementsflowwithtext,don’tstartonnewlines,ignorewidth/height,andonlyapplyhorizontalpadding/margins—idealforinlinetextstyling
Styling visited links differently with CSS Jul 11, 2025 am 03:26 AM
Setting the style of links you have visited can improve the user experience, especially in content-intensive websites to help users navigate better. 1. Use CSS's: visited pseudo-class to define the style of the visited link, such as color changes; 2. Note that the browser only allows modification of some attributes due to privacy restrictions; 3. The color selection should be coordinated with the overall style to avoid abruptness; 4. The mobile terminal may not display this effect, and it is recommended to combine it with other visual prompts such as icon auxiliary logos.
Creating custom shapes with css clip-path Jul 09, 2025 am 01:29 AM
Use the clip-path attribute of CSS to crop elements into custom shapes, such as triangles, circular notches, polygons, etc., without relying on pictures or SVGs. Its advantages include: 1. Supports a variety of basic shapes such as circle, ellipse, polygon, etc.; 2. Responsive adjustment and adaptable to mobile terminals; 3. Easy to animation, and can be combined with hover or JavaScript to achieve dynamic effects; 4. It does not affect the layout flow, and only crops the display area. Common usages are such as circular clip-path:circle (50pxatcenter) and triangle clip-path:polygon (50%0%, 100 0%, 0 0%). Notice
What is the CSS Painting API? Jul 04, 2025 am 02:16 AM
TheCSSPaintingAPIenablesdynamicimagegenerationinCSSusingJavaScript.1.DeveloperscreateaPaintWorkletclasswithapaint()method.2.TheyregisteritviaregisterPaint().3.ThecustompaintfunctionisthenusedinCSSpropertieslikebackground-image.Thisallowsfordynamicvis
How to create responsive images using CSS? Jul 15, 2025 am 01:10 AM
To create responsive images using CSS, it can be mainly achieved through the following methods: 1. Use max-width:100% and height:auto to allow the image to adapt to the container width while maintaining the proportion; 2. Use HTML's srcset and sizes attributes to intelligently load the image sources adapted to different screens; 3. Use object-fit and object-position to control image cropping and focus display. Together, these methods ensure that the images are presented clearly and beautifully on different devices.
What are common CSS browser inconsistencies? Jul 26, 2025 am 07:04 AM
Different browsers have differences in CSS parsing, resulting in inconsistent display effects, mainly including the default style difference, box model calculation method, Flexbox and Grid layout support level, and inconsistent behavior of certain CSS attributes. 1. The default style processing is inconsistent. The solution is to use CSSReset or Normalize.css to unify the initial style; 2. The box model calculation method of the old version of IE is different. It is recommended to use box-sizing:border-box in a unified manner; 3. Flexbox and Grid perform differently in edge cases or in old versions. More tests and use Autoprefixer; 4. Some CSS attribute behaviors are inconsistent. CanIuse must be consulted and downgraded.
- Match the