经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » CSS3 » 查看文章
使用CSS变量实现炫酷惊人的悬浮效果_css3_CSS
来源:jb51  时间:2019/4/28 8:44:59  对本文有异议

最近,我从 Grover网站上发现以一个好玩儿的悬停动画,也有了些自己的灵感。这个动画是将鼠标移动到订阅按钮上移动光标会显示相应的彩色渐变。这个想法很简单,但是它能使这个按钮脱颖而出,人们一下子就注意到它了,增加了点击的概率。

怎样才能达到这个效果,使我们的网站脱颖而出呢?其实,它并不像你想象的那么难!

追踪位置

我们要做的第一件事就是获取到鼠标的位置。

  1. document.querySelector('.button').onmousemove = (e) => {
  2. const x = e.pageX - e.target.offsetLeft
  3. const y = e.pageY - e.target.offsetTop
  4.  
  5. e.target.style.setProperty('--x', `${ x }px`)
  6. e.target.style.setProperty('--y', `${ y }px`)
  7.  
  8. }
  1. 选择元素,等待,直到用户将鼠标移过它;
  2. 计算相对于元素的位置;
  3. 将坐标存在CSS的变量中。

是的,仅仅9行代码就让你能获知用户放置鼠标的位置,通过这个信息你能达到意想不到的效果,但是我们还是先来完成CSS部分的代码。

动画渐变

我们先将坐标存储在CSS变量中,以便能够随时使用它们。

  1. .button {
  2. position: relative;
  3. appearance: none;
  4. background: #f72359;
  5. padding: 1em 2em;
  6. border: none;
  7. color: white;
  8. font-size: 1.2em;
  9. cursor: pointer;
  10. outline: none;
  11. overflow: hidden;
  12. border-radius: 100px;
  13.  
  14. span {
  15. position: relative;
  16. }
  17.  
  18. &::before {
  19. --size: 0;
  20.  
  21. content: '';
  22. position: absolute;
  23. left: var(--x);
  24. top: var(--y);
  25. width: var(--size);
  26. height: var(--size);
  27. background: radial-gradient(circle closest-side, #4405f7, transparent);
  28. transform: translate(-50%, -50%);
  29. transition: width .2s ease, height .2s ease;
  30. }
  31.  
  32. &:hover::before {
  33. --size: 400px;
  34. }
  35. }
  36.  
  1. 用span包裹文本,以避免显示在按钮的上方。
  2. 将 width和height初始化为0px,当用户悬停在按钮上时,将其改为400px。不要忘了设置这种转换以使其像风一样:dash:瞬间出现;
  3. 利用坐标追踪鼠标位置;
  4. 在background 属性上应用 radial-gradient,使用closest-side circle。Closest-side能够覆盖整个面。

总结
 

以上所述是小编给大家介绍的使用CSS变量实现炫酷惊人的悬浮效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对w3xue网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号