如何使用CSS3来制作消息提醒框

本篇内容主要讲解“如何使用CSS3来制作消息提醒框 ”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用CSS3来制作消息提醒框 ”吧!

成都创新互联专注骨干网络服务器租用十年,服务更有保障!服务器租用,德阳机房托管 成都服务器租用,成都服务器托管,骨干网络带宽,享受低延迟,高速访问。灵活、实现低成本的共享或公网数据中心高速带宽的专属高性能服务器。

现代Web设计技术允许开发者快速实现大多数浏览器支持的动画。我想警告消息是很常见的,因为默认的JavaScript警告框的样式往往(与你自己设计的漂亮样式)很不协调很囧。这使开发者步入找出哪种解决方案能更好地实现更友好的用户界面的道路。

如何使用CSS3来制作消息提醒框
    实际演示 – 下载源代码

建立页面

首先, 我们需要创建两个文件命名为“index.html” 和 “style.css”. 我将从Google cdn上调用最新的jQuery 库. HTML是非常简单的,因为我们只需要在警告框里加入一些文本. 所有的JavaScript代码被加在了页面的底部,这样可以节省HTTP请求时间.

XML/HTML Code复制内容到剪贴板

  1.   

  2.   

  3.   

  4.     

  5.   CSS3 Notification Boxes Demo  

  6.     

  7.     

  8.     

  9.     

  10.   

头部代码设置了外部调用文件和 HTML5文档规范 . 不是很复杂因为我们只是建立一个简单的示例. 对于提示窗口我定义两个不同的样式 – 成功的和错误的. 还有一些其它风格的例如警告框和信息框, 但是我没有创建更多的,因为我更关注的是效果.

XML/HTML Code复制内容到剪贴板

  1.   

  2.     

  3.     

  4.     

    Success!

      

  5.       

  6.     

    Thanks so much for your message. We check e-mail frequently and will try our best to respond to your inquiry.

      

  7.   

  

  •      

  •     

  •     

    Warning!

      

  •       

  •     

    You did not set the proper return e-mail address. Please fill out the fields and then submit the form.

      

  •   

  •   

  •      

  •   

    Click the error boxes to dismiss with a fading effect.

      

  •      

  •   

    Add more by appending dynamic HTML into the page via jQuery. Plus the notifications are super easy to customize.

      

  •      

  •     

  •     New Success Box  

  •     New Alert Box  

  •   

  •   

  •   

    每个图标文件来自 免费的PSD 和UI作品. 这些图标被我调整为适当的大小.如何你需要警告/信息图标你可以变变颜色创建成你自己的. 这个类名 .notify 被添加到每一个消息DIV上. 它定义了DIV的阴影和字体类型.

    其它的类例如 .successbox 和 .errorbox 充许我们改变颜色和alert窗口里的细节. 你可以看到在我的测试页里加载了两个alert窗口. 每个页面底部的按钮点击后可以在页上下方追加一个新的alert窗口.
     CSS 盒子样式

    我不会将太多 CSS 重置的细节,那些在我之前的教程中很明了了。我创建了一个默认的排版,并将内置 #content 的div居中。这样创建了一个允许jQuery在页面最上面添加新警告元素的盒子区域。

    CSS Code复制内容到剪贴板

    1. /** typography **/  

    2. h2 {   

    3.   font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;   

    4.   font-size: 2.5em;   

    5.   line-height: 1.5em;   

    6.   letter-spacing: -0.05em;   

    7.   margin-bottom: 20px;   

    8.   padding: .1em 0;   

    9.   color: #444;   

    10.  position: relative;   

    11.  overflow: hidden;   

    12.  whitewhite-space: nowrap;   

    13.  text-align: center;   

    14. }   

    15. h1:before,   

    16. h1:after {   

    17.   content: "";   

    18.   position: relative;   

    19.   display: inline-block;   

    20.   width: 50%;   

    21.   height: 1px;   

    22.   vertical-align: middle;   

    23.   background: #f0f0f0;   

    24. }   

    25. h1:before {       

    26.   left: -.5em;   

    27.   margin: 0 0 0 -50%;   

    28. }   

    29. h1:after {       

    30.   left: .5em;   

    31.   margin: 0 -50% 0 0;   

    32. }   

    33. h2 > span {   

    34.   display: inline-block;   

    35.   vertical-align: middle;   

    36.   whitewhite-space: normal;   

    37. }   

    38.   

    39. p {   

    40.   display: block;   

    41.   font-size: 1.35em;   

    42.   line-height: 1.5em;   

    43.   margin-bottom: 22px;   

    44. }   

    45.   

    46.   

    47. /** page structure **/  

    48. #w {   

    49.   display: block;   

    50.   width: 750px;   

    51.   margin: 0 auto;   

    52.   padding-top: 30px;   

    53. }   

    54.   

    55. #content {   

    56.   display: block;   

    57.   width: 100%;   

    58.   background: #fff;   

    59.   padding: 25px 20px;   

    60.   padding-bottom: 35px;   

    61.   -webkit-box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 2px 0px;   

    62.   -moz-box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 2px 0px;   

    63.   box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 2px 0px;   

    64. }   

    65.   

    66. .flatbtn {   

    67.   -webkit-box-sizing: border-box;   

    68.   -moz-box-sizing: border-box;   

    69.   box-sizing: border-box;   

    70.   display: inline-block;   

    71.   outline: 0;   

    72.   border: 0;   

    73.   color: #f9f8ed;   

    74.   text-decoration: none;   

    75.   background-color: #b6a742;   

    76.   border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);   

    77.   font-size: 1.2em;   

    78.   font-weight: bold;   

    79.   padding: 12px 22px 12px 22px;   

    80.   line-height: normal;   

    81.   text-align: center;   

    82.   vertical-align: middle;   

    83.   cursor: pointer;   

    84.   text-transform: uppercase;   

    85.   text-shadow: 0 1px 0 rgba(0,0,0,0.3);   

    86.   -webkit-border-radius: 3px;   

    87.   -moz-border-radius: 3px;   

    88.   border-radius: 3px;   

    89.   -webkit-box-shadow: 0 1px 0 rgba(15, 15, 15, 0.3);   

    90.   -moz-box-shadow: 0 1px 0 rgba(15, 15, 15, 0.3);   

    91.   box-shadow: 0 1px 0 rgba(15, 15, 15, 0.3);   

    92. }   

    93. .flatbtn:hover {   

    94.   color: #fff;   

    95.   background-color: #c4b237;   

    96. }   

    97. .flatbtn:active {   

    98.   -webkit-box-shadow: inset 0 1px 5px rgba(0, 0, 0, 0.1);   

    99.   -moz-box-shadow:inset 0 1px 5px rgba(0, 0, 0, 0.1);   

    100.   box-shadow:inset 0 1px 5px rgba(0, 0, 0, 0.1);   

    101. }  

    让效果更醒目的网页布局非常简单。任何熟悉前端网页开发的人都应该能够将其移植到自己的样式表中。我在这个扁平按钮中使用了特殊的样好似,并生成新的警告窗口。同样的,我更新了每个 .notify类元素的内部样式。

    CSS Code复制内容到剪贴板

    1. /** notifications **/  

    2. .notify {   

    3.   display: block;   

    4.   background: #fff;   

    5.   padding: 12px 18px;   

    6.   max-width: 400px;   

    7.   margin: 0 auto;   

    8.   cursor: pointer;   

    9.   -webkit-border-radius: 3px;   

    10.   -moz-border-radius: 3px;   

    11.   border-radius: 3px;   

    12.   margin-bottom: 20px;   

    13.   box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 2px 0px;   

    14. }   

    15.   

    16. .notify h2 { margin-bottom: 6px; }   

    17.   

    18. .successbox h2 { color: #678361; }   

    19. .errorbox h2 { color: #6f423b; }   

    20.   

    21. .successbox h1:before, .successbox h1:after { background: #cad8a9; }   

    22. .errorbox h1:before, .errorbox h1:after { background: #d6b8b7; }   

    23.   

    24. .notify .alerticon {    

    25.   display: block;   

    26.   text-align: center;   

    27.   margin-bottom: 10px;   

    28. }  

    我设置了一些在我的布局示例中运行良好的默认假设。所有消息通知窗口都被限定为 400px 宽,并通过使用 margin: 0 auto 在页面中居中。同时,我更新了鼠标图标为手指指针,这样用户就知道该元素可点击。我们需要创建一个 jQuery 事件监听器以用于获取用户对取消通知窗口的点击,并运行相应函数。
     jQuery动画

    我的JS代码实际执行了两个不同的操作。我们首先检测包含在#content DIV中的任何现有.notify元素。一旦用户点击这个.notify框元素,我们需要淡出这个通知盒到透明度为0%(display: none),然后从DOM中移除()此元素。

    JavaScript Code复制内容到剪贴板

    1. $(function(){   

    2.   $('#content').on('click', '.notify', function(){   

    3.     $(this).fadeOut(350, function(){   

    4.       $(this).remove(); // after fadeout remove from DOM  

    5.     });   

    6.   });  

    如果你熟悉jQuery,可能首先对这个选择器感到有些奇怪。我们并不是选择#content这个div,而是在寻找这个内容容器里面的任何.notify通知框。如果你查看一下jQuery的 .on() 方法文档,你会注意到我们可以传递另外一个选择器来作为第二个参数,它将在页面被渲染后更新。 这是一个Stack Overflow里出色的帖子,它非常详细地解释了这个概念。

    我的脚本的另一部分将会检查用户何时点击了页面下方的两个按钮之一。这两个按钮的ID是#newSuccessBox 和 #newAlertBox。无论用户何时点击,我们会停止加载HREF值的默认行为,代之以创建一个新的HTML块并前置在页面上。

    JavaScript Code复制内容到剪贴板

    1. // handle the additional windows  

    2. $('#newSuccessBox').on('click', function(e){   

    3.   e.preventDefault();   

    4.   var samplehtml = $(' 

      Success!

        

      You did not set the proper return e-mail address. Please fill out the fields and then submit the form.

       
    ').prependTo('#content');   

  • });   

  • $('#newAlertBox').on('click', function(e){   

  •   e.preventDefault();   

  •   var samplehtml = $(' 

    Warning!

      

    You did not set the proper return e-mail address. Please fill out the fields and then submit the form.

     ').prependTo('#content');   

  • });   

  • ;  

  • 每个函数都有它自己的变量,来包含一个我用于警告框的HTML的复制/粘贴镜像。这个HTML内容存储在一个字符串中用jQuery选择器转化为一个对象。我可以使用prependTo()方法选择这个内容DIV使新的警告框出现在页面的最上方。所有新的盒子也可以同样的方式被解除,因为它们的HTML代码和用静态HTML硬编码的盒子完全相同。

    到此,相信大家对“如何使用CSS3来制作消息提醒框 ”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


    新闻名称:如何使用CSS3来制作消息提醒框
    文章源于:http://csdahua.cn/article/geieic.html
    扫二维码与项目经理沟通

    我们在微信上24小时期待你的声音

    解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流

    其他资讯