使用useMutation和React Query发布数据demo

 更新时间:2022年12月13日 11:55:27   作者:Jovie  
这篇文章主要为大家介绍了使用useMutation和React Query发布数据demo,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

引言

我们已经学习了在使用react query与服务器通信时如何使用useQuery结构化你的应用程序。这次我们将学习如何以无缝的用户体验将数据发送到你的服务器。让我们直接进入这个坏小子。

为什么使用突变?

与查询非常不同,突变可以用来发布、删除或更新你的数据与反应查询,甚至来自你的服务器的任何副作用。而useMutation是用来执行这个的钩子。

useMutation在行动中

按照脚手架指南中的层模式,我们将在我们的 api.js层中写成

const addPlanet = async (data) => {
  const { name } = data;
  const body = { name };
  return axiosInstance({
    url: "planets",
    method: "POST",
    data: body,
  }).then(({ data }) => {
    return data;
  });
};

一旦我们准备好了api层,我们就可以在我们的自定义钩子中使用它了 钩子.js作为

const useAddPlanet = () => {
  const queryClient = useQueryClient();
  queryClient.setMutationDefaults(["add-planet"], {
    mutationFn: (data) => addPlanet(data),
    onMutate: async (variables) => {
      const { successCb, errorCb } = variables;
      return { successCb, errorCb };
    },
    onSuccess: (result, variables, context) => {
      if (context.successCb) {
        context.successCb(result);
      }
    },
    onError: (error, variables, context) => {
      if (context.errorCb) {
        context.errorCb(error);
      }
    },
  });
  return useMutation(["add-planet"]);
};

我们正在设置我们的突变默认值,第一个参数是查询键,然后是我们的突变函数,就像我们在 react query 中做的那样。这里的新成员是onMutate、onSuccess和onError

  • onMutate: 在突变时,可以用来处理请求过程中的一些副作用。
  • onSuccess: 在成功时,用于在请求被成功送达时做一些改变。
  • onError: 在错误发生时,用于处理你的请求失败或让我们说有一些错误,如404。

然后,我们用useMutation返回我们的突变与查询键。

消耗我们的突变

现在要在我们的组件内消耗我们的突变钩子,我们可以做一些事情,如

  const addPlanetMutation = useAddPlanet();

并在回调到我们的添加按钮时,我们可以这样做

  // ADD PLANET
  function handleAddPlanet() {
    const planetName = newPlanetInput.current.value;
    if (planetName === "") {
      return;
    }
    const mutationArgs = {
      name: newPlanetInput.current.value,
      successCb,
      errorCb,
    };
    addPlanetMutation.mutate(mutationArgs);
    newPlanetInput.current.value = null;
  }

我们已经准备好了突变参数,作为mutationsArgs,在这些参数中,我们有成功和错误的回调,将在我们的自定义钩子中调用。

成功和错误回调

在我们的错误回调中,我们可以添加一些警告或告知用户他们刚刚提出的请求已经失败,在我们的成功回调中,我们获取我们的数据。

什么是invalidateQueries?

当我们试图在一些副作用中再次获取我们的数据时,Invalidate查询就非常有用了。我们可以通过查询键作为参数,告诉反应查询到底是哪个请求或哪个缓存的数据需要再次获取:

  const successCb = () => {
    queryClient.invalidateQueries(["get-planets"]);
  };
  const errorCb = () => {};

无效查询加载

一旦我们的查询无效,我们就必须向用户显示某种指标,表明数据正在被获取,这也是由react query提供的

  const { data, isLoading, isFetching } = usePlanets();

isFetching是用来再次显示加载器的,还有addPlanetMuttion.isLoading

  {isLoading || addPlanetMutation.isLoading || isFetching ? (
      <InfinitySpin width="500" color="blue" />
  ) : (
  // SHOW COMPONENT
  )

bobs your uncle

以上就是使用useMutation和React Query发布数据demo的详细内容,更多关于useMutation React Query发布数据的资料请关注脚本之家其它相关文章!

相关文章

  • React 路由懒加载的几种实现方案

    React 路由懒加载的几种实现方案

    这篇文章主要介绍了React 路由懒加载的几种实现方案,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • react基于react-slick实现多图轮播效果

    react基于react-slick实现多图轮播效果

    React slick是一个使用React构建的轮播组件,下面这篇文章主要给大家介绍了关于react基于react-slick实现多图轮播效果的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • React使用Hooks从服务端获取数据的完整指南

    React使用Hooks从服务端获取数据的完整指南

    本文将从基础到高级用法,详细介绍如何在 React 项目中优雅地使用 Hooks 进行服务端数据获取,涵盖错误处理、加载状态、性能优化等核心场景,并提供可直接复用的代码模板,需要的朋友可以参考下
    2025-03-03
  • React封装CustomSelect组件思路详解

    React封装CustomSelect组件思路详解

    小编需要封装一个通过Popover弹出框里可以自定义渲染内容的组件,渲染内容暂时有: 单选框, 复选框,接下来通过本文给大家分享React封装CustomSelect组件思路,需要的朋友可以参考下
    2022-07-07
  • React+Typescript创建项目的实现步骤

    React+Typescript创建项目的实现步骤

    通过React组件库和TypeScript的强类型特性,开发者可以创建出具有优秀用户体验和稳定性的Web应用程序,本文主要介绍了React+Typescript创建项目的实现步骤,感兴趣的可以了解一下
    2023-08-08
  • React深入分析useEffect源码

    React深入分析useEffect源码

    useEffect是react v16.8新引入的特性。我们可以把useEffect hook看作是componentDidMount、componentDidUpdate、componentWillUnmounrt三个函数的组合
    2022-11-11
  • react实现复选框全选和反选组件效果

    react实现复选框全选和反选组件效果

    这篇文章主要为大家详细介绍了react实现复选框全选和反选组件效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • React Hook useState useEffect componentDidMount componentDidUpdate componentWillUnmount问题

    React Hook useState useEffect componentD

    这篇文章主要介绍了React Hook useState useEffect componentDidMount componentDidUpdate componentWillUnmount问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • React星星评分组件的实现

    React星星评分组件的实现

    评分插件在购物的应用中经常可以看得到,但是用着别人的总是没有自己写的顺手,本文就使用React实现星星评分组件,感兴趣的可以了解一下
    2021-06-06
  • React createRef循环动态赋值ref问题

    React createRef循环动态赋值ref问题

    这篇文章主要介绍了React createRef循环动态赋值ref问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01

最新评论