Example of how to implement underline effects using Css and JS

Example of how to implement underline effects using Css and JS

This article mainly describes two kinds of underline dynamic effects. The first one is that when hovering, the X-axis expands from the inside to the outside to achieve the animation effect. The second one is automatic display from left to right, or from right to left! !

The main effect is to use pseudo-class tags, hover, and transition to achieve animation effects.

The x-axis expands from inside to outside

The animation of the horizontal line is realized by using the Bezier curve. The specific code is as follows:

ul {
  display: flex;
  padding: 0;
  margin: 0;
  list-style-type: none;
}
ul:hover li:not(:hover) a {
  opacity: 0.2;
}
ul li {
  position: relative;
  padding: 30px 25px 30px 25px;
  cursor: pointer;
}
ul li::after {
  position: absolute;
  content: "";
  top: 100%;
  left: 0;
  width: 100%;
  height: 2px;
  background: #3498db;
  transform: scaleX(0);
  transition: 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}
ul li:hover::after, ul li.active::after {
  transform: scaleX(1);
}

Left and right horizontal underline animation effect

Mainly use js to determine the position of the mouse when it moves away, and display the animation effect by moving it left and right

The js code is as follows:

document.querySelectorAll('a').forEach(elem => {

  elem.onmouseenter =
  elem.onmouseleave = e => {

    const tolerance = 5;

    const left = 0;
    const right = elem.clientWidth;

    let x = e.pageX - elem.offsetLeft;

    if (x - tolerance < left) x = left;
    if (x + tolerance > right) x = right;

    elem.style.setProperty('--x', `${x}px`);

  };

});

CSS uses pseudo-class tags to implement animation effects
The css code is as follows:

a {
  position: relative;
  font-weight: 600;
  text-decoration: none;
  color: rgba(0, 0, 0, 0.4);
  transition: color .3s ease;
}
a::after {
  --scale: 0;
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 3px;
  background: #4c81c9;
  -webkit-transform: scaleX(var(--scale));
          transform: scaleX(var(--scale));
  -webkit-transform-origin: var(--x) 50%;
          transform-origin: var(--x) 50%;
  transition: -webkit-transform 0.3s cubic-bezier(0.535, 0.05, 0.355, 1);
  transition: transform 0.3s cubic-bezier(0.535, 0.05, 0.355, 1);
  transition: transform 0.3s cubic-bezier(0.535, 0.05, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.535, 0.05, 0.355, 1);
}
a:hover {
  color: #4c81c9;
}
a:hover::after {
  --scale: 1;
}

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

<<:  Navicat connection MySQL error description analysis

>>:  Analysis of the pros and cons of fixed, fluid, and flexible web page layouts

Recommend

MySQL installation tutorial under Centos7

MySQL installation tutorial, for your reference, ...

Summary of the use of element's form elements

There are many form elements. Here is a brief sum...

Examples of preview functions for various types of files in vue3

Table of contents Preface 1. Preview of office do...

JavaScript to switch multiple pictures

This article shares the specific code of JavaScri...

HTML table markup tutorial (48): CSS modified table

<br />Now let's take a look at how to cl...

How to develop uniapp using vscode

Because I have always used vscode to develop fron...

The implementation process of long pressing to identify QR code in WeChat applet

Preface We all know that the QR codes in official...

Detailed explanation of MySQL database binlog cleanup command

Overview Today I will mainly share how to correct...

Nginx memory pool source code analysis

Table of contents Memory Pool Overview 1. nginx d...

How to deploy MySQL 5.7 & 8.0 master-slave cluster using Docker

> Deploy MySQL 5.7 cluster master & slave ...

Summary of common Mysql DDL operations

Library Management Create a library create databa...

Analysis of multi-threaded programming examples under Linux

1 Introduction Thread technology was proposed as ...