前端判断网络状态并提示

在后台系统访问,有时候会遇到断网或者网络不好得时候,所以这里需求是在请求发送之前判断网络环境,如果断网给出提示,弱网超过一定时间提示请求超时

1、封装判断断网函数统一封装

这里使用得是window的一个属性navigator

复制代码
function checkConnectionStatus() {
  const networkType = window.navigator.onLine;
    if (!networkType) {
      // 网络速度慢,给出提示
      message({
        type: "error",
        message: "当前网络未连接,请检查网络!"
      });
      return false
    }
    return true
}
2、在请求封装的函数前先判断网络情况

如果断网直接提示,并不走请求逻辑

复制代码
/**
 * post方法,对应post请求
 * @param {String} url [请求的url地址]
 * @param {Object} params [请求时携带的参数]
 */
export function post(url, params, isLoading = true) {
  // 在发送请求之前判断网络状态
  const flag = checkConnectionStatus()
  if(!flag) return
  if (isLoading == true) {
    var loadingInstance = Loading.service({
      lock: true,
      text: "加载中...",
      background: "rgba(255, 255, 255, 0.3)"
    });
  }
  return new Promise((resolve, reject) => {
    Axios.post(url, QS.stringify(params))
      .then(res => {
        if (loadingInstance) {
          setTimeout(() => {
            loadingInstance.close();
          }, 0);
        }
        resolve(res.data);
      })
      .catch(err => {
        if (loadingInstance) {
          setTimeout(() => {
            loadingInstance.close();
          }, 0);
        }        
        reject(err.data);
      });
  });
}
3、弱网情况下提示请求超时

这里需要在响应拦截器中做判断

3.1、设定超时时间
复制代码
// 设置请求超时
Axios.defaults.timeout = 20000;
3.2、拦截器判断
复制代码
Axios.interceptors.response.use(
···
// 服务器状态码不是成功的情况
  error => {
    if (error.message.includes("timeout")) {
      message({
        type: "error",
        message: "网络连接超时,请检查网络"
      });
      return Promise.reject(error.response);
    } else if (error.response.status) {
        // 其他错误,直接抛出错误提示
        default:
          break;
      }
      return Promise.reject(error.response);
    }
  }
)

这样子就可以啦,是不是很容易!!!

相关推荐
数智化管理手记6 小时前
精益生产中的TPM管理是什么?一文破解设备零故障的密码
服务器·网络·数据库·低代码·制造·源代码管理·精益工程
晓晓hh6 小时前
JavaSE学习——迭代器
java·开发语言·学习
Laurence6 小时前
C++ 引入第三方库(一):直接引入源文件
开发语言·c++·第三方库·添加·添加库·添加包·源文件
kyriewen117 小时前
你点的“刷新”是假刷新?前端路由的瞒天过海术
开发语言·前端·javascript·ecmascript·html5
014-code7 小时前
String.intern() 到底干了什么
java·开发语言·面试
421!7 小时前
GPIO工作原理以及核心
开发语言·单片机·嵌入式硬件·学习
摇滚侠7 小时前
JAVA 项目教程《苍穹外卖-12》,微信小程序项目,前后端分离,从开发到部署
java·开发语言·vue.js·node.js
@insist1238 小时前
网络工程师-生成树协议(STP/RSTP/MSTP)核心原理与应用
服务器·开发语言·网络工程师·软考·软件水平考试
末日汐8 小时前
传输层协议UDP
linux·网络·udp
野生技术架构师8 小时前
2026年牛客网最新Java面试题总结
java·开发语言