Ajax请求时loading加载图的实现

在写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。

或者引入cdn

这里,有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)在标签中设置显示loading图的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请求返回的间隙显示,这样用户体验就会更加良好。




你可能感兴趣的:(前端)