Hướng dẫn scroll smooth css - cuộn css mượt mà

Hướng dẫn scroll smooth css - cuộn css mượt mà

Đã đăng vào thg 12 19, 2019 8:16 SA 1 phút đọc 1 phút đọc

  • Smooth scrolling (sự thay đổi vị trí từ liên kết ban đầu đến vị trí cuối) là một animation rất tốt cho trang web, mang lại cảm giác trải nghiệm mượt mà bóng bẩy.

  • Đây là code thực hiện việc cuộn trang một cách trơn tru đến một điểm trên cùng một page. Nó tích hợp một số logic để xác định các jump link, và không nhắm vào các link khác.

  • xét ví dụ dưới đây . Khi ta click vào thẻ Go to Section2 nó sẽ chuyển để section 2 . khi click vào Go to Section 3 sẽ chuyển đến section 3 . CLick vào top sẽ quay về đầu trangGo to Section2 nó sẽ chuyển để section 2 . khi click vào Go to Section 3 sẽ chuyển đến section 3 . CLick vào top sẽ quay về đầu trang

Tạo HTML

  • Tạo list ul có 2 nút click section 2 và section 3. sao cho attribute có href = # +id của thẻ cần scroll đến
  • Tạo id khi scroll đến

Smooth Page Scrolling

Section 1

Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus

Section 2

quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus

Section 3

quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus

Top

Tạo Jquery

  • Đầu tiên ta xác định thẻ khi ta click vào nó sẽ di chuyển đến 1 vị trí nào trong page ta có. Chẳng hạn như khi click Go to Section 2 nó sẽ di chuyển đến h2 có id là "two"Go to Section 2 nó sẽ di chuyển đến h2 có id là "two"
var data_id = $(this).attr('href'); // trả ra id mà bạn click. ví dụ Go to Section 2 với href="#two" thì với đoạn này ta sẽ nhận dc #two
  • Bước tiếp theo là di chuyển đến điểm bạn cần nó scroll. với khoảng thời gian nhất định như ví dụ dưới là 0.5s
$('html, body').animate({
    scrollTop: $(data_id).offset().top
  }, '500');

Xem demo ở codepen bên dưới đây :

Kết Luận

  • Qua bài này mình đã hướng dẫn các bạn Smooth scrolling dễ dàng và hiệu quả . Các bạn thấy có nhiều cách hay hơn có thể chia sẻ qua cmt nhé. Cảm ơn
  • Link tham khảo :
    • https://css-tricks.com/snippets/jquery/smooth-scrolling/

All rights reserved

Hướng dẫn scroll smooth css - cuộn css mượt mà

Đã đăng vào Jan 18th, 2021 10:17 a.m. 1 phút đọc 1 phút đọc

Giới thiệu

Chào mọi nguời ! Hôm nay mình xin chia sẻ 1 techical nhỏ nhưng rất hữu ích khi tạo smooth scroll anchor link chỉ bằng CSS mà không cần dùng đến JS. Bình thường khi tạo anchor link scroll đến target hay page khác để sao cho muợt mà mọi người sẽ viết 1 đoạn JS đúng không nhỉ, nhưng chỉ với 1 dòng CSS sẽ giúp chúng ta tiết kiệm được nhiều thời gian và rất đơn giản.

Cách làm

Để làm được cái này chúng ta sẽ sử dụng CSS properties scroll-behavior và pseudo-class :focus-within vào thẻ HTML.

  • scroll-behavior : là 1 thuộc tính được set cho việc scroll ở trong 1 box khi 1 anchor nhận được 1 trigger scroll nó sẽ scroll tới target đó Để hiểu hơn mọi người có thể vào đây và thao tác thử với ví dụ sẽ dễ hiểu hơn nhiều. https://developer.mozilla.org/en-US/docs/Web/CSS/scroll-behavior
  • :focus-within: để chỉ ra 1 element đã nhận được focus hay chứa các element trong đó đã nhận được focus https://developer.mozilla.org/en-US/docs/Web/CSS/:focus-within

Chúng ta sẽ viết dạng global cho toàn bộ element nằm trong thẻ HTML thì những element bên trong khi được scroll đến khi bấm vào anchor link sẽ có scroll khi nhận được focus

1.HTML Với HTML chỉ cần seting đơn giản thế này.

<a href="#content">Eventa>
<div id="content">Event Areaa>

2.CSS CSS chúng ta sẽ để giá trị cho scroll-behavior

var data_id = $(this).attr('href'); // trả ra id mà bạn click. ví dụ Go to Section 2 với href="#two" thì với đoạn này ta sẽ nhận dc #two
1 nhé.

html:focus-within {
scroll-behavior: smooth;
}

Lời kết

Hi vọng tip nhỏ này sẽ giúp cho các bạn còn chưa biết đến có thể dễ dàng tạo 1 nội dung điều dướng với anchor scroll một cách muợt mà , không cần sử dụng đến Javascript.

All rights reserved