IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> React中使用SWR处理数据请求 -> 正文阅读

[JavaScript知识库]React中使用SWR处理数据请求

React中使用SWR处理数据请求

在做React项目开发的时候,我们一般都会直接使用axios插件或者fetch进行数据的获取。但是这一次给大家介绍一个插件库SWR,算是网络数据请求的一个补充吧。

先上官网地址:https://swr.vercel.app/zh-CN

SWR

SWR是一个用于数据请求的 React Hooks 库,使用 SWR组件可以实时的获取服务器最新的数据。借用官方的说明:“SWR” 这个名字来自于 stale-while-revalidate:一种由 HTTP RFC 5861 推广的 HTTP 缓存失效策略。这种策略首先从缓存中返回数据(过期的),同时发送 fetch 请求(重新验证),最后得到最新数据。

当我们重新聚焦一个页面或在标签页之间切换时重新获取最新的数据,或者也可以自行设置一个获取数据的时间间隔(refreshInterval)。

安装

npm i swr
# or
yarn add swr

使用npm或者yarn在react项目中安装swr插件。

使用

const { data, error, isValidating, mutate } = useSWR(key, fetcher, options)

参数

  • key: 请求的唯一 key string
  • fetcher:(可选)一个请求数据的 Promise 返回函数
  • options:(可选)该 SWR hook 的选项对象

返回值

  • data: 通过 fetcher 用给定的 key 获取的数据(如未完全加载,返回 undefined)
  • error: fetcher 抛出的错误(或者是 undefined)
  • isValidating: 是否有请求或重新验证加载
  • mutate(data?, shouldRevalidate?): 更改缓存数据的函数

data表示数据,可以修改缓存的数据,一般在数据改变的时候使用,可以结合post请求操作

是否需要和服务器上的数据进行比对校验

选项

  • revalidateOnFocus = true: 窗口聚焦时自动重新验证
  • refreshInterval = 0: 轮询间隔 (默认 disabled)

在使用时,我只列出了最常用的一些配置信息。其他的可以参考官方文档

文档地址:https://swr.vercel.app/zh-CN/docs/options

举个例子

import React from 'react';
import useSWR from 'swr';

const fetcher = (url) => fetch(url).then((res) => res.json());

const SwrDemo = () => {
  const { data, error } = useSWR('/api/pets', fetcher);
  // console.log(error);
  if (error) return <div>failed to load</div>;
  if (!data) return <div>loading...</div>;
  return <div>{data.length}</div>;
};

export default SwrDemo;

比如,只想使用swr实现一个简单的实时获取服务器最新数据的功能,可以直接设置refreshInterval参数,设置一个获取刷新数据的间隔时间,这样子客户端代码就会轮询的方式进行接口的调用。

当我们的页面重新聚焦或者标签页切换的时候会自动的获取最新的数据,也就是说只要用户返回打开了我们的项目,那么使用了swr包装的网络请求,都会尽心再一次的数据获取,保证页面以最新的数据展示。

参数传递

在调用fetcher的时候如果要传递多个参数,可以使用数组的形式进行传递。

// 默认情况下,key 将作为参数传递给 fetcher
useSWR('/api/user', () => fetcher('/api/user'))
useSWR('/api/user', url => fetcher(url))
useSWR('/api/user', fetcher)

如果需要传递多个参数,那么参数使用数组的形式进行组织,比如:

const fetcher = (url, id) => {
  console.log(url, id);
  return fetch(url).then((res) => res.json());
};
const SwrDemo = () => {
  const { data, error } = useSWR(['/api/pets', 111], fetcher);
  ...
};
...

重新验证数据

swr中的mutate方法可以通过指定可以的形式,触发所有相同key的请求进行数据校验,更新最新值。比如

import useSWR, { mutate } from 'swr'
...
const SwrDemo = () => {
  const { data, error } = useSWR('/api/pets', fetcher);
  ...
  <button onClick={()=>mutate('/api/pets')}>手动更新</button>
};
...

更改数据

import React from 'react';
import useSWR, { mutate as M } from 'swr';

const fetcher = (url) => {
  return fetch(url).then((res) => res.json());
};

const SwrDemo = () => {
  const { data, error, mutate } = useSWR('/api/pets', fetcher);
  if (error) return <div>failed to load</div>;
  if (!data) return <div>loading...</div>;
  console.log(data);
  return (
    <div>
      <ul>
        {data.map((item) => (
          <li key={item._id}>{item.name}</li>
        ))}
      </ul>
      <button
        onClick={() => {
          // 点击添加的时候使用改变当前key对应的缓存数据的方法,只对本地数据做修改
          //  当前所做的修改是没有结合api接口的,所以此处不做服务器端校验
          //    参数二传递false
          mutate(
            [...data, { _id: Date.now(), name: '小明' + Math.random() }],
            false
          );
        }}
      >
        添加
      </button>
      <hr />
      {data.length} <hr />
      <button onClick={() => M('/api/pets')}>手动更新</button>
    </div>
  );
};

export default SwrDemo;

此例子演示的效果是数据在本地做缓存更改,手动更新按钮点击之后会重新和服务器的数据做比对,获取服务器最新的数据进行显示。如果需要更新服务器的数据,可以结合api接口发送对应的请求实现

总结

SWR是一个神奇的插件,使用它可以为我们的项目带来更好的体验。这里只是列出来了一些常用的方法,如果想了解更多,可以看下官方文档中的更多说明。

*陆荣涛前端学习交流Q群858752519
加群备注:CSDN推荐
请添加图片描述

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-07-03 10:40:34  更:2022-07-03 10:44:15 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 9:55:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码