通过JS和CSS,实现网页加载中的动画效果
2017-10-13 14:49
1066 查看
需要材料:
一张loading动画的gif图片基本逻辑:
模态框遮罩 + loading.gif动图,默认隐藏模态框
页面开始发送Ajax请求数据时,显示模态框
请求完成,隐藏模态框
下面我们通过Django新建一个web应用,来简单实践下
实践
新建一个Django项目,创建应用app01, 配置好路由和static,略。将gif动图放到静态文件夹下,结构如下:视图中定义一个函数,它返回页面
test.html:
def test(request): return render(request, 'test.html')
test.html页面如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <!-- 导入css样式 --> <link rel="stylesheet" href="/static/css/loading.css"> <!-- 导入jquery 和 js文件 --> <script src="/static/plugins/jquery-3.2.1.js"></script> <script src="/static/js/loading.js"></script> </head> <body> <h1>你好啊,朋友!</h1> <hr> <div id="content"> <p>正在请求服务器数据....</p> </div> <!-- 模态框部分 --> <div class="loading hide"> <div class="gif"></div> </div> </body> </html>
CSS样式如下:
/* 模态框样式 */ .loading { position: fixed; top: 0; bottom: 0; right: 0; left: 0; background-color: black; opacity: 0.4; z-index: 1000; } /* 动图样式 */ .loading .gif { height: 32px; width: 32px; background: url('/static/img/loading.gif'); position: fixed; left: 50%; top: 50%; margin-left: -16px; margin-top: -16px; z-index: 1001; }
说明:
通过设置
position: fixed,并令上下左右为0,实现模态框覆盖整个页面;
设置gif动态图为背景,居中,来显示加载效果;
通过设置z-index值,令gif图悬浮在模态框上面;
background-color: black;是为了看着明显,具体使用时可以设为
white;
JS文件如下:
$(function () { //准备请求数据,显示模态框 $('div.loading').show(); $.ajax({ url: "/ajax_handler.html/", type: 'GET', data: {}, success: function (response) { var content = response.content; $('#content').html(content); //请求完成,隐藏模态框 $('div.loading').hide(); }, error: function () { $('#content').html('server error...'); //请求完成,隐藏模态框 $('div.loading').hide(); } }) });
说明:
页面载入后,开始发送Ajax请求,从服务端
ajax_handler视图请求数据,这时显示模态框
请求完成后,不论成功与否,隐藏模态框
ajax_handler视图如下,它模拟网络延迟,并返回一些字符串:
from django.http import JsonResponse from django.utils. b669 safestring import mark_safe # 取消字符串转义 def ajax_handler(request): # 模拟网络延迟 import time time.sleep(3) msg = ''' XXX ''' # 这里你可以随便放入一些字符串 return JsonResponse({"content": mark_safe(msg)})
效果如下:
如果显示不了gif动图,可能是浏览器缓存问题。项目完整代码在这里:https://github.com/Ayhan-Huang/Loading
相关文章推荐
- JS+CSS实现网页加载中的动画效果
- js实现绿白相间竖向网页百叶窗动画切换效果
- js+css简单实现网页换肤效果
- js通过iframe加载外部网页的实现代码
- JS实现超炫网页烟花动画效果的方法
- 原生JS实现CSS动画效果
- css实现加载中loading动画效果
- css+js实现的网页常见选项卡效果
- JS+CSS实现Google首页的动画效果
- swiper切换动画效果,需要先加载swiper.animate.min.js和animate.min.css。
- jQuery实现彩带延伸效果的网页加载条loading动画
- 10个CSS和jQuery的加载中(loading)动画效果实现
- js实现绿白相间竖向网页百叶窗动画切换效果
- google曾经的首页小图标,JS+CSS实现的动画效果
- JS+CSS实现鼠标经过弹出一个DIV框完整实例(带缓冲动画渐变效果)
- 通过JS控制CSS实现连帧动画
- 异步加载js文件并执行js方法:实现异步处理网页的复杂效果(转)
- js实现网页预加载动画
- 异步加载js文件并执行js方法:实现异步处理网页的复杂效果
- JS实现网页右侧带动画效果的伸缩窗口代码