js调用轮询接口

北城以北 提交于 2019-11-30 04:22:52
项目中遇到需要很多个需要轮询处理的接口,然后简单的封装了下,做个记录,以后用到类似的直接copy
// polling-utils.js

/**
     * @descripting 轮询功能
     * @param {String} type 请求类型
     * @param {String} url 地址 
     * @param {Object} data 请求数据 
     * @param {Number} delay 轮询间隔时间
     */
    export default function polling(type, url, data, delay = 1000) {
        return new Promise((resolve, reject) =>{
            ajax[type](url, data).then(res => {
                if (res.data === 'polling') {
                    setTimeout(() => {
                        resolve(polling(type, url, data));
                    }, delay)
                } else {
                   resolve(res);
               }
           })
       })
    }

用法

import polling from 'utils/polling-utils';

polling('post', url, data).then(res => { console.log(res) })

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!