CSS制作图形变形弹出效果的示例分享

前端技术 2023/09/08 CSS

弹出窗体是网页常用的一个交互设计,在这个注重交互动画体验的时代,网页弹窗也可以来点新鲜的点子,比如今天分享的CSS 变形Modal Window。

当用户点击按钮时,按钮将会变成一个全屏的屏幕,然后再显示内容,整个展示过程流畅友好,也许你可以尝试到你的新项目上。

演示页:http://codyhouse.co/gem/morphing-modal-window/
点击“Fire Modal Window”按钮后,按钮将会慢慢变大,直到整个屏幕。下面来个GIF演示:

使用教程

本代码兼容Chrome, Firefox, Safari, Opera,而IE需要9.0或以上版本(IE9+)

STEP 1: 创建HTML布局

XML/HTML Code复制内容到剪贴板
  1. <section class=\"cd-section\">  
  2. <!-- section content here -->  
  3.   
  4. <div class=\"cd-modal-action\">  
  5. <a href=\"#0\" class=\"btn\" data-type=\"modal-trigger\">Fire Modal Window</a> <!— 这是窗体按钮 -->  
  6. <span class=\"cd-modal-bg\"></span>  
  7. </div>  
  8.   
  9. <div class=\"cd-modal\">  
  10. <div class=\"cd-modal-content\">  
  11. <!— 这是窗体内容区域 -->  
  12. </div>  
  13. </div>  
  14.   
  15. <a href=\"#0\" class=\"cd-modal-close\">Close</a> <!— 这是关闭按钮 -->  
  16. </section>  

STEP 2: 添加CSS样式

CSS Code复制内容到剪贴板
  1. .cd-modal-action {   
  2. positionrelative;   
  3. }   
  4. .cd-modal-action .btn {   
  5. width: 12.5em;   
  6. height: 4em;   
  7. background-color#123758;   
  8. border-radius: 5em;   
  9. transition: color 0.2s 0.3s, width 0.3s 0s;   
  10. }   
  11. .cd-modal-action .btn.to-circle {   
  12. width: 4em;   
  13. colortransparent;   
  14. transition: color 0.2s 0s, width 0.3s 0.2s;   
  15. }   
  16. .cd-modal-action .cd-modal-bg {   
  17. positionabsolute;   
  18. top: 0;   
  19. left: 50%;   
  20. transform: translateX(-2em);   
  21. width: 4em;   
  22. height: 4em;   
  23. background-color#123758;   
  24. border-radius: 50%;   
  25. opacity: 0;   
  26. visibilityhidden;   
  27. transition: visibility 0s 0.5s;   
  28. }   
  29. .cd-modal-action .cd-modal-bg.is-visible {   
  30. opacity: 1;   
  31. visibilityvisible;   
  32. }  

STEP 3: 添加jQuery

本代码使用了jQuery,你可以通过下面代码来修改窗口大小。

JavaScript Code复制内容到剪贴板
  1. var btnRadius = $(\'.cd-modal-bg\').width()/2,   
  2. left = $(\'.cd-modal-bg\').offset().left + btnRadius,   
  3. top = $(\'.cd-modal-bg\').offset().top + btnRadius - $(window).scrollTop(),   
  4. scale = scaleValue(top, left, btnRadius, $(window).height(), $(window).width());   
  5.   
  6. function scaleValue( topValue, leftValue, radiusValue, windowW, windowH) {   
  7. var maxDistHor = ( leftValue > windowW/2) ? leftValue : (windowW - leftValue),   
  8. maxDistVert = ( topValue > windowH/2) ? topValue : (windowH - topValue);   
  9. return Math.ceil(Math.sqrt( Math.pow(maxDistHor, 2) + Math.pow(maxDistVert, 2) )/radiusValue);   
  10. }  

本文地址:https://www.stayed.cn/item/22111

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。