CSS+JS实现爱心点赞按钮(代码示例)

本篇文章给大家介绍一下css+js实现一个“爱之满满”点赞按钮的方法,希望对大家有所帮助!

CSS+JS实现爱心点赞按钮(代码示例)

前段时间在看一档说唱节目,被里面的一个说唱歌手JBcob爱之满满这句词给洗脑了。

于是这次给大家带来一个爱之满满的点赞按钮,让大家在点赞的同时还能感受到被爱包裹的感觉。

1.png

立即学习“前端免费学习笔记(深入)”;

ToDoList

爱心按钮引导点赞爱之满满

Just Do It

❤️ 爱心按钮

制作一个爱心的方式有很多,可以用图标库的爱心,可以写一个svg,可以用图片,我这里就用伪元素的方式做一个爱心。(学习视频分享:css视频教程)

/* fullLove.css */.heart{    background-color: #8a93a0;    height: 13px;    width: 13px;    transform: rotate(-45deg) scale(1);    display: inline-block;}.heart::before {    content: '';    position: absolute;    top: -50%;    left: 0;    background-color: inherit;    border-radius: 50%;    height: 13px;    width: 13px;}.heart::after {    content: '';    position: absolute;    top: 0;    right: -50%;    background-color: inherit;    border-radius: 50%;    height: 13px;    width: 13px;}

再给外层加一些阴影就可以出来拟态化效果

2.png

引导点赞

我们需要让按钮做出一些视觉效果来引导观众姥爷们点赞,那持续震动无疑是一种好的选择。

// love.jsconst likeBtn = document.getElementById('likeBtn');const heart=document.getElementById('heart')likeBtn.addEventListener('mousemove',() => {  heart.classList.add('heratPop')})likeBtn.addEventListener('mouseout',() => {  heart.classList.remove('heratPop')})
/* fullLove.css */.heratPop{    animation: pulse 1s linear infinite;}@keyframes pulse {    0% {            transform: rotate(-45deg) scale(1);    }    10% {            transform: rotate(-45deg) scale(1.1);    }    20% {            transform: rotate(-45deg) scale(0.9);    }    30% {            transform: rotate(-45deg) scale(1.2);    }    40% {            transform: rotate(-45deg) scale(0.9);    }    50% {            transform: rotate(-45deg) scale(1.1);    }    60% {            transform: rotate(-45deg) scale(0.9);    }    70% {            transform: rotate(-45deg) scale(1);    }}

3.gif

爱之满满

接下来就是最主要的爱之满满了,怎么样才能达到这种效果呢,那必然是越多的爱越好啊。那我们想办法让爱心漂浮在按钮周围,在规定时间内爱心进行位移并消失即可。创建一个元素可以使用document.createElement,移除元素可以使用DOMremove()剩下的就简单了,只需要在这个过程中不同的爱心设置不同的大小和位移即可。核心代码(完整代码请看文末):

// love.jsfunction addHearts(content) {  for(let i=0; i {      const fullHeart = document.createElement('div');      fullHeart.classList.add('hearts');      fullHeart.innerHTML = '';      fullHeart.style.left = Math.random() * 100 + '%';      fullHeart.style.top = Math.random() * 100 + '%';      fullHeart.style.transform = `translate(-50%, -50%) scale(${Math.random()+0.3}) `      fullHeart.style.animationDuration = Math.random() * 2 + 3 + 's';      fullHeart.firstChild.style.backgroundColor='#ed3056'      content.appendChild(fullHeart);      setTimeout(() => {        fullHeart.remove();      }, 3000);    }, i * 100)  }}
/* fullLove.css */.hearts {    position: absolute;    color: #E7273F;    font-size: 15px;    top: 50%;    left: 50%;    transform: translate(-50%, -50%);    animation: fly 3s linear forwards;}@keyframes fly {    to {        transform: translate(-50%, -50px) scale(0);    }}

我们来看看最终的效果吧~在线演示地址

4.gif

写在最后

首先感谢大家看到这里,这次分享的是爱之满满点赞效果,希望可以帮助到有需要的同学。

更多编程相关知识,请访问:编程学习!!

以上就是CSS+JS实现爱心点赞按钮(代码示例)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1621878.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
normalize和css reset分别是什么文件?又有什么区别?
上一篇 2025年12月24日 07:39:54
下一篇 2025年12月24日 07:40:08

相关推荐

  • 前端测试中如何模拟JavaScript的定时器行为?

    使用 Jest 等工具模拟定时器可避免测试延迟和不稳定性,通过 jest.useFakeTimers() 替换真实定时器,结合 jest.advanceTimersByTime() 控制时间推进,并用 jest.clearAllTimers() 清理状态,确保测试隔离与可预测性。 在前端测试中,模拟…

    2026年5月10日
    000
  • CSS中块级元素水平居中布局指南

    本文详细介绍了在CSS中实现块级元素水平居中的核心方法,重点讲解了如何通过设置margin-left: auto;和margin-right: auto;来使具有固定宽度的块级元素在其父容器中居中显示。文章通过具体代码示例,阐明了这一常用技巧的原理与应用,并提供了相关注意事项,帮助开发者有效解决布局…

    2026年5月10日
    100
  • 如何在游览器中调试js

    通过使用浏览器调试工具调试 JavaScript,您可以在浏览器中完成以下操作:在源代码中设置断点以暂停执行并检查变量值;在控制台中输入代码片段以立即执行并检查错误消息;分析网络请求以识别性能问题;查看内存使用和垃圾回收情况以诊断内存泄漏。 如何在浏览器中调试 JS 如何打开浏览器的调试工具? 大多…

    2026年5月10日
    000
  • Linux lighttpd配置,HTML引用CSS响应如电!

    首先确保MIME类型正确配置,通过启用mod_mime模块并添加“.css”对应“text/css”类型;其次启用mod_alias和mod_staticfile模块,配置静态文件路径映射,将CSS文件存放于指定目录并通过URL正确引用;最后加载mod_setenv模块,设置Cache-Contro…

    2026年5月10日
    000
  • XAMPP零报错引用CSS,HTML本地站丝滑运行!

    首先确认CSS文件路径正确并存放于htdocs项目目录,如mywebsite/style.css;使用相对路径在HTML中引用;通过http://localhost/mywebsite/index.html访问页面,避免直接双击打开;检查apache/conf/mime.types包含text/cs…

    2026年5月10日
    000
  • HTMLrev 上的免费 HTML 网站模板

    HTMLrev 是唯一的人工策划的库专门专注于免费 HTML 模板,适用于由来自世界各地慷慨的模板创建者制作的网站、登陆页面、投资组合、博客、电子商务和管理仪表板世界。 这个人就是我自己 Devluc,我已经工作了 1 年多来构建、改进和更新这个很棒的免费资源。我自己就是一名模板制作者,所以我知道如…

    2026年5月10日
    300
  • 如何在HTML表格中合并单元格?rowspan和colspan怎么用?

    如何在HTML表格中合并单元格?rowspan和colspan怎么用?如何在HTML表格中合并单元格?rowspan和colspan怎么用?如何在HTML表格中合并单元格?rowspan和colspan怎么用?如何在HTML表格中合并单元格?rowspan和colspan怎么用?

    使用rowspan和colspan合并html表格单元格时,常见错误包括span值与实际覆盖单元格数量不匹配、后续行未减少被合并单元格对应的td、嵌套表格增加复杂性、影响可访问性和响应式设计。1.确保span值与实际覆盖单元格数量一致;2.使用rowspan时删除后续行中被占用的td;3.避免过度嵌…

    2026年5月10日 用户投稿
    000
  • JavaScript Flow类型检查

    Flow是Facebook开发的JavaScript静态类型检查工具,通过在文件顶部添加// @flow注释启用,支持逐步集成。安装flow-bin后运行npx flow init初始化配置,并在package.json中添加flow脚本。它提供number、string、boolean、Array…

    2026年5月10日
    000
  • 使用Flexbox构建高性能响应式头部导航:优化移动端布局与汉堡菜单兼容性

    本教程详细介绍了如何利用Flexbox技术构建一个响应式头部导航栏,以解决在不同屏幕尺寸下布局混乱及汉堡菜单不显示的问题。通过优化HTML结构和CSS样式,文章展示了如何实现桌面端横向排列与移动端垂直堆叠的自适应布局,确保用户体验的一致性和导航的可用性。 引言 在现代网页设计中,响应式布局已成为不可…

    2026年5月10日
    100
  • js中join()方法的使用

    join() 方法用于将数组元素连接成字符串,不修改原数组。默认以逗号分隔,可自定义分隔符,空数组返回空字符串,null 或 undefined 转为空字符串。 在 JavaScript 中,join() 是数组的一个内置方法,用于将数组中的所有元素连接成一个字符串。这个方法不会修改原数组,而是返回…

    2026年5月10日
    000
  • 复杂约束下利用CSS选择器定位元素:非nth和非属性选择的策略

    本文旨在探讨在严格CSS选择器限制下,如何精准定位HTML元素,特别是当`:nth-child`系列伪类、属性选择器`[data-target]`以及兄弟选择器`+`和`~`均被禁用时。文章将通过一个具体的案例,详细解析如何巧妙地结合`:first-child`、`:last-child`和`:no…

    2026年5月10日
    000
  • Svelte中实现变量的首次条件赋值与非响应式管理

    在svelte应用中,对于滚动条高度这类一旦确定便通常保持不变的静态值,持续的响应式计算会造成不必要的性能开销。本教程将介绍一种优化策略,通过结合使用常规变量和条件响应式语句,实现变量的首次条件赋值。一旦满足特定条件并获取到有效值后,变量将停止后续的响应式更新,从而提高应用效率和可预测性。 引言:S…

    2026年5月10日
    000
  • css如何设置文字颜色

    css设置文字颜色的方法:1、在DIV标签内使用color颜色样式,代码为【www.php.cn】;2、在CSS选择器中使用color颜色样式CSS代码。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css设置文字颜色的方法: 1、在DIV标签内使用color颜色样式 w…

    2026年5月10日
    000
  • 如何在多个文件输入框中实现独立图片预览功能

    本教程详细阐述了如何在网页中实现多个文件输入框(`input type=”file”`)的独立图片预览功能。通过识别并解决常见错误,如重复id导致的元素选择不当,我们将演示如何利用dom遍历和事件委托,为每个上传区域动态绑定预览逻辑,确保用户上传的每张图片都能在其对应的位置正…

    2026年5月10日
    000
  • 如何理解Event Loop机制并对代码执行顺序进行精准控制?

    Event Loop通过宏任务与微任务协调异步执行,同步代码先运行,随后清空微任务队列再执行宏任务,如:console.log(‘1’)、’4’同步输出,Promise.then入微任务队列输出’3’,setTimeout入宏任…

    2026年5月10日
    000
  • 实现图标逐个延迟显示的动画效果

    实现图标逐个延迟显示的动画效果实现图标逐个延迟显示的动画效果实现图标逐个延迟显示的动画效果实现图标逐个延迟显示的动画效果

    本文将介绍如何使用 JavaScript 和 CSS 结合的方式,实现一个图标容器中图标逐个延迟显示的动画效果。通过 JavaScript 获取容器中的子元素,并利用 setTimeout 函数为每个图标添加一个 CSS 类,该 CSS 类定义了图标的过渡效果,从而实现图标的逐个延迟显示。 HTML…

    2026年5月10日 用户投稿
    000
  • 使用CSS实现鼠标悬停时保持显示的下拉菜单

    本文介绍了如何使用纯CSS实现下拉菜单在鼠标悬停时保持显示,以及鼠标移开后隐藏的交互效果。通过利用CSS的:hover伪类,可以避免使用JavaScript,简化代码并提高性能。同时,也讨论了这种方法在键盘可访问性方面的局限性,并提供了相应的注意事项。 使用CSS :hover 伪类实现下拉菜单 实…

    2026年5月10日
    000
  • Linux用grep递归查找项目中未使用的CSS类名

    先提取CSS文件中的类名,再从HTML和JS中找出使用的类名,最后对比得出未使用类。具体步骤:1. 用grep递归提取./css/下所有以.开头的类选择器,去除点并去重保存为css_classes.txt;2. 在./src/中搜索class属性内的类名,支持引号和模板字符串,提取单词形式的类名去重…

    2026年5月10日
    000
  • HTML文档侧边栏怎么创建_HTMLaside标签使用指南

    答案:创建HTML侧边栏需用语义化标签结合CSS布局实现。首先用包裹相关但非核心的内容,如推荐链接、广告等,再通过Flexbox、Grid或Float等CSS技术将侧边栏定位在页面一侧;推荐使用Flexbox或Grid以提升响应式表现,并注意处理内容过多时的滚动与粘性定位,以及内容过少时的视觉平衡问…

    2026年5月10日
    000
  • html5网页制作用什么软件

    为制作引人入胜的 HTML5 网页,推荐的软件包括:Adobe Dreamweaver:功能全面的编辑器,具有直观的用户界面。Visual Studio Code:跨平台代码编辑器,支持语法高亮显示和版本控制。WebStorm:专业级 JavaScript IDE,提供针对 HTML5 的高级支持。…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信