Apollo学习-useMutation的使用

一、useMutation

useMutation是一个 React Hook,它通常与 Apollo Client 一起使用,用于在 React 应用程序中执行 GraphQL 突变(Mutation)操作。这个 Hook 提供了一个简单的 API 来发送 GraphQL 突变请求,并处理响应和错误。

二、使用

1、导入useMutation

从@apollo/client包中导入useMutation

import { useMutation } from '@apollo/client';

2、定义Graphql突变

定义一个Graphql突变,通常是一个字符串,表示你想要执行的突变操作

const ADD_TODO = gql`mutation AddTodo($text: String!) {addTodo(text: $text) {idtextcompleted}}
`;

3、调用定义的Graphql突变

const [addTodo, { data, loading, error }] = useMutation(ADD_TODO);

突变的发生不是由useMutation执行引起的,而是由定义的Graphql突变引起的,在本文中,既执行addTodo函数发生突变。 

4、执行突变

当你想要添加一个待办事项时,你可以调用 addTodo 函数,并传入必要的变量

const handleAddTodo = (text) => {addTodo({ variables: { text } });
};

5、响应错误

在组件中根据data、loading、error来更新UI或处理错误

if (error) {console.error(error);
} else if (data) {console.log(data);
} else if(loading) {console.log(loading);
} 

三、

useMutation hook返回一个数组,我们可以将其分解为两个元素。在第一个元素中,我们返回一个函数,在这种情况下,我们可以调用它执行我们的突变操作。对于下一个元素,我们可以再次分解一个对象该对象返回给我们loading , error和data 。

import { useMutation } from "@apollo/react-hooks";
import { gql } from "apollo-boost";const CREATE_POST = gql`mutation CreatePost($title: String!, $body: String!) {insert_posts(objects: { body: $body, title: $title }) {affected_rows}}
`;function NewPost() {const [title, setTitle] = React.useState("");const [body, setBody] = React.useState("");const [createPost, { loading, error }] = useMutation(CREATE_POST);function handleCreatePost(event) {event.preventDefault();// the mutate function also doesn't return a promisecreatePost({ variables: { title, body } });}return (<div><h1>New Post</h2><form onSubmit={handleCreatePost}><input onChange={(event) => setTitle(event.target.value)} /><textarea onChange={(event) => setBody(event.target.value)} /><button disabled={loading} type="submit">Submit</button>{error && <p>{error.message}</p>}</form></div>);
}

但是,与查询不同,我们不使用loading或error来有条件地渲染某些内容。 我们通常在诸如提交表单的情况下使用loading ,以防止多次提交表单,以避免不必要地执行相同的更改(如您在上面的示例中看到的)。

我们使用error向用户显示我们的突变出了什么问题。 例如,如果未提供突变所需的某些值,则我们可以轻松地使用该错误数据在页面中有条件地呈现错误消息,以便用户希望可以解决问题。

与将变量传递给useMutation的第二个参数useMutation ,当某些事情发生时,例如当突变完成和出现错误时,我们可以访问几个有用的回调。 这些回调分别命名为onCompleted和onError 。

onCompleted回调使我们可以访问返回的突变数据,并且在完成突变后执行某些操作(例如转到另一个页面)非常有帮助。 当突变存在问题时, onError回调为我们提供了返回的错误,并为我们提供了处理错误的其他模式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/40724.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ForkJoin框架与工作窃取算法详解

文章目录 一、ForkJoin框架概述1_核心概念2_主要类和方法1_ForkJoinPool2_ForkJoinTask 二、启用异步模式与否的区别三、ForkJoinPool的三种任务提交方式四、执行逻辑及使用示例1_示例&#xff1a;并行计算数组元素和2_forkJoinPool.submit3_ForkJoinTask<?>中任务的执行…

实现第一个神经网络

PyTorch 包含创建和实现神经网络的特殊功能。在本节实验中&#xff0c;将创建一个简单的神经网络&#xff0c;其中一个隐藏层开发一个输出单元。 通过以下步骤使用 PyTorch 实现第一个神经网络。 第1步 首先&#xff0c;需要使用以下命令导入 PyTorch 库。 In [1]: import…

解决mysql数据库连接报错:Authentication plugin ‘caching_sha2_password‘ cannot be loaded

解决mysql数据库连接报错&#xff1a;Authentication plugin ‘caching_sha2_password’ cannot be loaded OperationalError: (2059, “Authentication plugin ‘caching_sha2_password’ cannot be loaded: /usr/lib/mysql/plugin/caching_sha2_password.so: cannot open sha…

启动Nuxt-hub-starter: Failed to initialize wrangler bindings proxy write EOF

重新安装 node.js 这样做可以确保下载到了适合的 Windows 框架、Chocolatey&#xff08;一款Windows包管理工具&#xff09;、Python 等资源。 这个错误与Node版本、pnpm/yarn 的版本无关&#xff01; Node.js — Download Node.js (nodejs.org)

Selenium 监视数据收发

实际上&#xff0c;在我提供的示例中&#xff0c;确实使用了浏览器实例。webdriver.Chrome()这行代码正是创建了一个Chrome浏览器的WebDriver实例。Selenium Wire扩展了标准的Selenium WebDriver&#xff0c;允许你通过这个浏览器实例来监听网络请求。 当你运行类似这样的代码…

汉光联创HGLM2200N黑白激光多功能一体机加粉及常见问题处理

基本参数&#xff1a; 机器型号&#xff1a;HGLM2200N 产品名称&#xff1a;A4黑白激光多功能一体机 基础功能&#xff1a;打印、扫描、复印 打印速度&#xff1a;22页/分钟 纸张输入容量&#xff1a;150-249页 单面支持纸张尺寸&#xff1a;A4、A5、A6 产品尺寸&#x…

MySQL数据恢复(适用于误删后马上发现)

首先解释一下标题&#xff0c;之所以适用于误删后马上发现是因为太久了之后时间和当时操作的数据表可能会记不清楚&#xff0c;不是因为日志丢失 1.首先确保自己的数据库开启了binlog&#xff08;我的是默认开启的我没有配置过&#xff09; 根据这篇博客查看自己的配置和自己…

MS32008N低压 5V 多通道电机驱动器

MS32008N 是一款多通道电机驱动芯片&#xff0c;其中包 含两路步进电机驱动&#xff0c;一路直流电机驱动&#xff1b;每个步 进电机驱动通道的最大工作电流 1.0A &#xff1b;支持两相四 线与四相五线步进电机。 芯片采用可选的 I 2 C 或 SPI 串行总线控制模式&…

安装 Mamba、Conv1d 时报错 “bare_metal_version“

报错详情1&#xff08;pip install mamba/causal_conv1d&#xff09;&#xff1a; Preparing metadata (setup.py) ... errorerror: subprocess-exited-with-error python setup.py egg_info did not run successfully.│ exit code: 1╰─> [13 lines of output]/tmp/pip-…

鸿蒙开发HarmonyOS NEXT (三) 熟悉ArkTs

一、自定义组件 1、自定义组件 自定义组件&#xff0c;最基础的结构如下&#xff1a; Component struct Header {build() {} } 提取头部标题部分的代码&#xff0c;写成自定义组件。 1、新建ArkTs文件&#xff0c;把Header内容写好。 2、在需要用到的地方&#xff0c;导入…

centos7 安装mysql8.0.34

在 CentOS 7 上安装 MySQL 8.0.34 的步骤如下&#xff1a; 1. 卸载 MariaDB&#xff08;如果已安装&#xff09; CentOS 7 默认使用 MariaDB 作为数据库管理系统&#xff0c;因此在安装 MySQL 之前需要卸载 MariaDB。 rpm -qa | grep mariadb rpm -e --nodeps mariadb-libs-5…

Linux 摄像头编号固化

一、前言 在工业领域&#xff0c;一台设备会有很多个摄像头&#xff0c;可以使用命令&#xff1a;ll /dev/video* 进行查看&#xff1b; 在代码中&#xff0c;如果需要使用摄像头&#xff0c;那么都是需要具体到哪个摄像头编号的&#xff0c;例如 open("/dev/video4"…

[Day 24] 區塊鏈與人工智能的聯動應用:理論、技術與實踐

AI在自動駕駛中的應用 1. 簡介 自動駕駛技術是現代交通領域的一個革命性進展。通過結合人工智能&#xff08;AI&#xff09;、機器學習&#xff08;ML&#xff09;、深度學習&#xff08;DL&#xff09;和傳感器技術&#xff0c;自動駕駛汽車可以在無人干預的情況下安全駕駛。…

线段树求区间最值问题

引言 今天主要还是练了两道题&#xff0c;是有关线段树如何去求一个区间内的最值问题的&#xff0c;我们可以用线段树来解决。 对应一个无法改变顺序的数组&#xff0c;我们想要去求一个区间内的最值&#xff0c;假设有n个结点&#xff0c;m次询问&#xff0c;暴力的解决办法…

51、基于主成分分析和聚类分析的基因表达分析(matlab)

1、主成分分析和聚类分析简介 主成分分析(Principal Component Analysis, PCA)和聚类分析(Cluster Analysis)是两种常用的数据分析方法,用于降维和数据分类。 1)主成分分析(PCA) 主成分分析是一种常用的多元统计数据分析方法,旨在通过找到数据中最重要的变量(主成…

股票分析-20240628

今日关注&#xff1a; 20240626 六日涨幅最大: ------1--------300386--------- 飞天诚信 五日涨幅最大: ------1--------300386--------- 飞天诚信 四日涨幅最大: ------1--------300386--------- 飞天诚信 三日涨幅最大: ------1--------300386--------- 飞天诚信 二日涨幅最…

基于go-gmsm静态库编写的SM2椭圆曲线公钥密码算法PHP扩展 相较于openssl-ext-sm2编译更方便 增加了密文指定排序、识别ans1编码等功能

go-ext-sm2 介绍 基于go-gmsm静态库编写的SM2椭圆曲线公钥密码算法PHP扩展 相较于openssl-ext-sm2编译更方便 增加了密文指定排序、识别ans1编码等功能 特性:非对称加密 git地址:https://gitee.com/state-secret-series/go-ext-sm2.git 软件架构 zend 常规PHP扩展结构 …

vue-org-tree搜索到对应项高亮展开

效果图&#xff1a; 代码&#xff1a; <template><div class"AllTree"><el-form :inline"true" :model"formInline" class"demo-form-inline"><el-form-item><el-input v-model"formInline.user&quo…

c++ using namespace std的作用及注意事项

在C中&#xff0c;using namespace std; 是一个常见的指令&#xff0c;它用于简化标准库&#xff08;Standard Library&#xff09;中类和函数的引用。下面我将详细解释这个指令的作用和使用时的注意事项。 作用 在c/c标准库中&#xff0c;许多类和函数的定义都在std(standar…

【Git】远程仓库操作

创建远程仓库 在官网进行注册登录&#xff1a;Gitee或Github 进入后点击新建仓库&#xff0c;默认选项创建即可 **仓库创建完成后可以看到SSH的仓库地址&#xff1a;gitgitee.com:username/test.git**或gitgithub.com:Toukensan/test.git 配置SSH公钥 在本地通过命令行创建…