search
HomeWeb Front-endCSS TutorialHow to achieve smooth scrolling to anchor position using CSS

How to achieve smooth scrolling to anchor position using CSS

Nov 21, 2023 pm 03:28 PM
csssmooth scrollinganchor point

How to achieve smooth scrolling to anchor position using CSS

How to use CSS to achieve smooth scrolling to the anchor position

In web design, the anchor position refers to a specific position on the page. When the user clicks on the page When linked, the page will smoothly scroll to that location. This effect not only brings a good user experience, but also improves the beauty of the page. This article will introduce how to use CSS to achieve smooth scrolling to the anchor point position, and give specific code examples.

1. HTML structure

First, we need to set anchor points in HTML. Add an id attribute to the position where smooth scrolling is required as the identifier of the anchor point. For example:

<div id="section1">
  <!-- 具体内容 -->
</div>

<div id="section2">
  <!-- 具体内容 -->
</div>

In the code, we have created two anchor positions, which are set to section1 and section2 using the id attribute.

2. CSS Style

Next, we need to set the CSS style to achieve a smooth scrolling effect. First, we will add a scrolling behavior transition to the body element. In CSS, we can use the scroll-behavior attribute to set the scrolling behavior to smooth scrolling. The code is as follows:

body {
  scroll-behavior: smooth;
}

In this way, when we click the anchor link, the page will scroll smoothly to the target position.

3. Add anchor link

In order to smoothly scroll to the anchor position, we need to add an anchor link to the page. Where you need to scroll to, such as a navigation menu or other link location, use an a tag to create a link, and set the link's href attribute to the ID of the anchor location. For example:

<a href="#section1">跳转到Section 1</a>
<a href="#section2">跳转到Section 2</a>

In this way, when the user clicks on the link, the page will scroll smoothly to the corresponding anchor position.

4. Compatibility considerations

Although the above method can work normally in most modern browsers, the scroll-behavior attribute may not be supported in some older versions of browsers. To ensure it works properly in all browsers, we can use JavaScript to achieve a smooth scrolling effect.

// JavaScript代码示例

$('a[href*="#"]').on('click', function(e){
  e.preventDefault();

  $('html, body').animate(
    {
      scrollTop: $($(this).attr('href')).offset().top,
    },
    800,
    'linear'
  );
});

This code will use animation effects to smoothly scroll to the anchor position when the anchor link is clicked. It should be noted that the jQuery library needs to be introduced to achieve this effect.

Summary

Through the scroll-behavior property of CSS, we can easily achieve a smooth scrolling effect. Of course, in order to ensure that it works properly on different browsers, we can also use JavaScript to achieve this effect. Whether it is CSS or JavaScript, the smooth scrolling effect can enhance the user experience and make web pages smoother and more beautiful. Applying this technology to web design can improve the quality and user evaluation of the website.

The above is the detailed content of How to achieve smooth scrolling to anchor position using CSS. For more information, please follow other related articles on the PHP Chinese website!

Statement
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
Simulating Mouse MovementSimulating Mouse MovementApr 22, 2025 am 11:45 AM

If you've ever had to display an interactive animation during a live talk or a class, then you may know that it's not always easy to interact with your slides

Powering Search With Astro Actions and Fuse.jsPowering Search With Astro Actions and Fuse.jsApr 22, 2025 am 11:41 AM

With Astro, we can generate most of our site during our build, but have a small bit of server-side code that can handle search functionality using something like Fuse.js. In this demo, we’ll use Fuse to search through a set of personal “bookmarks” th

Undefined: The Third Boolean ValueUndefined: The Third Boolean ValueApr 22, 2025 am 11:38 AM

I wanted to implement a notification message in one of my projects, similar to what you’d see in Google Docs while a document is saving. In other words, a

In Defense of the Ternary StatementIn Defense of the Ternary StatementApr 22, 2025 am 11:25 AM

Some months ago I was on Hacker News (as one does) and I ran across a (now deleted) article about not using if statements. If you’re new to this idea (like I

Using the Web Speech API for Multilingual TranslationsUsing the Web Speech API for Multilingual TranslationsApr 22, 2025 am 11:23 AM

Since the early days of science fiction, we have fantasized about machines that talk to us. Today it is commonplace. Even so, the technology for making

Jetpack Gutenberg BlocksJetpack Gutenberg BlocksApr 22, 2025 am 11:20 AM

I remember when Gutenberg was released into core, because I was at WordCamp US that day. A number of months have gone by now, so I imagine more and more of us

Creating a Reusable Pagination Component in VueCreating a Reusable Pagination Component in VueApr 22, 2025 am 11:17 AM

The idea behind most of web applications is to fetch data from the database and present it to the user in the best possible way. When we deal with data there

Using 'box shadows' and clip-path togetherUsing 'box shadows' and clip-path togetherApr 22, 2025 am 11:13 AM

Let's do a little step-by-step of a situation where you can't quite do what seems to make sense, but you can still get it done with CSS trickery. In this

See all articles

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

Video Face Swap

Video Face Swap

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

Hot Tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.