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

所属分类: 网页制作 / CSS 阅读数: 316
收藏 0 赞 0 分享

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

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

201647140742917.png (500×341)

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

使用教程

本代码兼容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. }  
更多精彩内容其他人还在看

CSS入门教程:计算CSS盒模型宽和高

 出处:当我们布局一个网页的时候,经常会遇到这样的一种情况,那就是最终网页成型的宽度或是高度会超出我们预先的计算,其实就就是所谓的CSS的盒模型造成的。 #test{margin:10px;padding:10px;width:100px;height:100px;}
收藏 0 赞 0 分享

在IE流览器中正确显示PNG透明图片

  png图片有很好的品质。阴影效果也不会有杂边,很流畅。如果插入网页的话可以给网站内容增色不少!更重要的是在不增加图片容量大小的情况下提高了页面的图片的质量。对于有复杂背景,如:在有颜色过度背景上插入不规则边框的图片带来极大很便利!   但目前IE中对于插入
收藏 0 赞 0 分享

CSS教程:DIV底部放置文字

  css对文字的布局上没有靠容器底部对齐的参数,目前使用的一个不错的方法也比较好.就是用position属性来解决,看下面的代码,用position的相对和绝对定位功能也轻松的实现了,文字靠近div低部对齐,并且靠近的距离还可以精确到像素,自己可以调节,是不是很不错呢?
收藏 0 赞 0 分享

如何用CSS让文字居于div的底部

  这个问题是别人提出的,因为css对文字的布局上没有靠容器底部对齐的参数,(或许有但是我没有发现)不过目前我使用的一个不错的方法也比较好.就是用position属性来解决,看下面的代码,我用position的相对和绝对定位功能也轻松的实现了,文字靠近div低部对齐,并且靠近
收藏 0 赞 0 分享

从A页面连接到B页面后并直接把B页面的隐藏层显示

  这个效果实现的是,在B页面里有两个层,一个显示层,我们暂定名c层,一个是隐藏层,我们暂定名d层,单独进B页面的时候,c层显示,d层隐藏,然而从A页面连接到B页面的时候,则是让d层显示,c层隐藏,我觉得这个效果对网页设计者以后会有很大帮助,现在把代码发出来,
收藏 0 赞 0 分享

CSS样式表定义标签li前面样式

定义LI前面的小点样式 view plaincopy to clipboardprint? 语法: list-style-type : disc | circle | square | decimal | lower-roman | upper-roman | lowe
收藏 0 赞 0 分享

符合标准的div css制作的弹出菜单

本文介绍了五款符合标准的div css制作的弹出菜单,而且不含有js的. NO.1最基本的:二级dropdown弹出菜单 <!DOCTYPE html PUB
收藏 0 赞 0 分享

CSS实现在文章每段后面加入带连接的隐藏文字

代码主要理解3个参数:createElement、createTextNode、appendChild。这3个js参数分别是创建元素、创建字符、追加节点。代码原理:循环页面段落标签<p>,创建连接元素<a>,创建要显示的连接字符,用SetAttribute
收藏 0 赞 0 分享

CSS:浏览器特定选择器介绍

当你想在一个浏览器里改变样式而不像在其他浏览器中改变时,这些选择器很有用。 IE6以下 *html{} IE 7 以下 *:first-child html {} * html {} 只对IE 7 *:first-child html {} 只对IE 7
收藏 0 赞 0 分享

WEB标准学习,认识两种网页声明的含义

即网页标准推出来以后,我们时常会看到两种不同的网页的声明,一个是Dhtml,一个是Xhtml。如下所示: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "ht
收藏 0 赞 0 分享
查看更多