Web Front-end
CSS Tutorial
How to use pure CSS to achieve the hover effect of buttons (source code attached)How to use pure CSS to achieve the hover effect of buttons (source code attached)
The content of this article is about how to use pure CSS to achieve the hover effect of buttons (source code attached). It has certain reference value. Friends in need can refer to it. I hope it will be useful to you. helped.
Effect preview

Source code download
https://github.com/comehope/front- end-daily-challenges
Code Interpretation
Define dom, the container is an unordered list, containing 4 elements, representing 4 buttons:
- home
- products
- services
- contact
Centered display:
body {
margin: 0;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
background: cornsilk;
}
Remove the symbol in front of the list item:
ul {
padding: 0;
list-style-type: none;
}
Set the button's border and background style. The background uses a gradient color, but the direction of the gradient alternates in sequence:
ul li {
box-sizing: border-box;
width: 15em;
height: 3em;
font-size: 20px;
border-radius: 0.5em;
margin: 0.5em;
box-shadow: 0 0 1em rgba(0,0,0,0.2);
}
ul li:nth-child(odd) {
background: linear-gradient(to right, orange, tomato);
}
ul li:nth-child(even) {
background: linear-gradient(to left, orange, tomato);
}
Set the button The style of the text above, alternately left or right:
ul li {
color: white;
font-family: sans-serif;
text-transform: capitalize;
line-height: 3em;
}
ul li:nth-child(odd) {
text-align: left;
padding-left: 10%;
}
ul li:nth-child(even) {
text-align: right;
padding-right: 10%;
}
Set the perspective effect of the button, rotate left and right alternately, the perspective distance at this time is 500px, please note The order of the perspective() function and the rotateY() function cannot be written in reverse:
ul li:nth-child(odd) {
transform: perspective(500px) rotateY(45deg);
}
ul li:nth-child(even) {
transform: perspective(500px) rotateY(-45deg);
}
Adds a hover effect to the button, so that the perspective distance when hovering is shortened to 200px, the longer the perspective distance The shorter, the larger the rotation will appear:
ul li:nth-child(odd):hover {
transform: perspective(200px) rotateY(45deg);
padding-left: 5%;
}
ul li:nth-child(even):hover {
transform: perspective(200px) rotateY(-45deg);
padding-right: 5%;
}
Finally, set an easing time to smooth the effect transition:
ul li {
transition: 0.3s;
cursor: pointer;
}
You're done!
The above is the detailed content of How to use pure CSS to achieve the hover effect of buttons (source code attached). For more information, please follow other related articles on the PHP Chinese website!
The Many Ways to Link Up Shapes and Images with HTML and CSSApr 16, 2025 am 09:45 AMDifferent website designs often call for a shape other than a square or rectangle to respond to a click event. Perhaps your site has some kind of tilted or
Web Developer Search HistoryApr 16, 2025 am 09:41 AMSophie Koonin blogged "Everything I googled in a week as a professional software engineer," which was a fascinating look into the mind of a web developer and
What happens when you open a new install of browsers for the 1st time?Apr 16, 2025 am 09:29 AMInteresting research from Jonathan Sampson, where he watches the network requests a browser makes the very first time you launch it on a fresh install, and
Web Development Merit BadgesApr 16, 2025 am 09:26 AMA collection of front-end development achievements. How many can you collect?
Clipping, Clipping, and More Clipping!Apr 16, 2025 am 09:22 AMThere are so many things you can do with clipping paths. I've been exploring them for quite some time and have come up with different techniques and use cases
Breakout ButtonsApr 16, 2025 am 09:09 AMAndy covers a technique where a semantic is used within a card component, but really, the whole card is clickable. The trick is to put a pseudo-element that


Hot AI Tools

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

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

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Chinese version
Chinese version, very easy to use

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

Zend Studio 13.0.1
Powerful PHP integrated development environment

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.

Atom editor mac version download
The most popular open source editor








