在写Ajax请求时,会有请求延迟,想到了想要用loading图来接替延迟。网上找了许多官方文档,包括blockUI,但是不知道什么原因,js包是导入成功了的,但总是出现$.blockUI is not a function的错误,所以只好另找方法。无意间找到了spin,这也是非常好用的一个动画插件spin.js。
官网:点击打开链接
下面简单介绍一下快速使用步骤:
1)引入spin.min.js文件
注意,在引入spin.min.js文件之前,要先导入jquery.js文件,因为spin.min.js依赖于jquery。
<script type="text/javascript" src="/js/spin.min.js"></script>
或者引入cdn
<script src="https://cdn.bootcss.com/spin.js/2.3.2/spin.min.js"></script>
这里,有spin.min.js下载链接:点击打开链接
2)设置opts样式,也就是loading图的样式,这个opts样式可以在官网在线制作和测试;然后初始化spin
var opts = {
lines: 13, // 花瓣数目
length: 20, // 花瓣长度
width: 10, // 花瓣宽度
radius: 30, // 花瓣距中心半径
corners: 1, // 花瓣圆滑度 (0-1)
rotate: 0, // 花瓣旋转角度
direction: 1, // 花瓣旋转方向 1: 顺时针, -1: 逆时针
color: '#5882FA', // 花瓣颜色
speed: 1, // 花瓣旋转速度
trail: 60, // 花瓣旋转时的拖影(百分比)
shadow: false, // 花瓣是否显示阴影
hwaccel: false, //spinner 是否启用硬件加速及高速旋转
className: 'spinner', // spinner css 样式名称
zIndex: 2e9, // spinner的z轴 (默认是2000000000)
top: 'auto', // spinner 相对父容器Top定位 单位 px
left: 'auto'// spinner 相对父容器Left定位 单位 px
};
var spinner = new Spinner(opts);
3)在<body>标签中设置显示loading图的div
<div id="myspin"></div>
4)在ajax请求中加入spin
$.ajax({
url:"url",
type:"get",
beforeSend:function () {//ajax处理之前出现spin图标
//异步请求时spinner出现
$("#myspin").text("");
var target = $("#myspin").get(0);
spinner.spin(target);//显示loading图标
},
success:function (result) {
}
setTimeout(function () {//ajax请求成功0.3秒以后,关闭loading图标
//ajax处理之后,关闭spinner
spinner.spin();
},300);
}
});
这样,loading图标就能在ajax请求返回的间隙显示,这样用户体验就会更加良好。