使用CSS 和 JavaScript 实现鼠标悬停时图片放大、缩小和抖动

我们可以通过 CSS 和 JavaScript 来实现鼠标悬停时图片放大、缩小和抖动的效果。以下是一个简单的实现方式:

1.HTML 结构

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>鼠标悬停效果</title>
    <link rel="stylesheet" href="styles.css">
</head>
<body>
    <div class="image-container">
        <img src="your-image.jpg" alt="Image" class="hover-image">
    </div>

    <script src="script.js"></script>
</body>
</html>

2.CSS 样式

css 复制代码
/* 基本样式 */
.image-container {
    display: inline-block;
    position: relative;
    overflow: hidden;
}

.hover-image {
    width: 100%;
    transition: transform 0.3s ease, filter 0.1s ease;
}

/* 鼠标悬停时的放大和抖动效果 */
.image-container:hover .hover-image {
    transform: scale(1.2) rotate(5deg); /* 放大并轻微旋转 */
    animation: shake 0.5s ease-in-out infinite;
}

/* 抖动动画 */
@keyframes shake {
    0% {
        transform: scale(1.2) rotate(5deg) translateX(0);
    }
    25% {
        transform: scale(1.2) rotate(5deg) translateX(-5px);
    }
    50% {
        transform: scale(1.2) rotate(5deg) translateX(5px);
    }
    75% {
        transform: scale(1.2) rotate(5deg) translateX(-5px);
    }
    100% {
        transform: scale(1.2) rotate(5deg) translateX(0);
    }
}

3.JavaScript (可选)

js 复制代码
const image = document.querySelector('.hover-image');

image.addEventListener('mouseenter', () => {
    image.classList.add('hover');
});

image.addEventListener('mouseleave', () => {
    image.classList.remove('hover');
});

说明:

  • 放大效果:使用 transform: scale(1.2) 来放大图片。你可以根据需要调整放大的比例。
  • 抖动效果:使用 @keyframes 定义了一个简单的抖动动画,通过 translateX 来实现图片左右的抖动。
  • 旋转效果 :rotate(5deg) 给图片添加了一个微小的旋转效果,增加视觉动感。
    这个效果会在鼠标悬停时使图片放大、抖动,并且在鼠标离开时恢复到原样。
相关推荐
冰暮流星35 分钟前
css之线性渐变
前端·css
徐同保41 分钟前
tailwindcss暗色主题切换
开发语言·前端·javascript
mapbar_front1 小时前
大厂精英为何在中小公司水土不服?
前端
生莫甲鲁浪戴1 小时前
Android Studio新手开发第二十七天
前端·javascript·android studio
细节控菜鸡3 小时前
【2025最新】ArcGIS for JS 实现随着时间变化而变化的热力图
开发语言·javascript·arcgis
2501_916008893 小时前
Web 前端开发常用工具推荐与团队实践分享
android·前端·ios·小程序·uni-app·iphone·webview
SkylerHu4 小时前
前端代码规范:husky+ lint-staged+pre-commit
前端·代码规范
菜鸟una4 小时前
【微信小程序 + 消息订阅 + 授权】 微信小程序实现消息订阅流程介绍,代码示例(仅前端)
前端·vue.js·微信小程序·小程序·typescript·taro·1024程序员节
Yeats_Liao4 小时前
Go Web 编程快速入门 05 - 表单处理:urlencoded 与 multipart
前端·golang·iphone
飞翔的佩奇4 小时前
【完整源码+数据集+部署教程】【运动的&足球】足球场地区域图像分割系统源码&数据集全套:改进yolo11-RFAConv
前端·python·yolo·计算机视觉·数据集·yolo11·足球场地区域图像分割系统