如何使用 Express.js 实现 GraphQL 的 API

AI 编程助手,豆包旗下的编程助手,提供智能补全、智能预测、智能问答等能力,节省开发时间,释放脑海中的创造力,支持 VSCode,点击体验 AI

GraphQL 是一种用于 API 的查询语言,它提供了一种更高效、更强大、更灵活的方式来获取数据。而 Express.js 是一种流行的 Node.js Web 框架,它可以帮助我们轻松地构建 Web 应用程序。在本文中,我们将讨论如何使用 Express.js 实现 GraphQL 的 API。

安装依赖

首先,我们需要安装必要的依赖。我们将使用以下软件包:

  • express: Express.js Web 框架。
  • express-graphql: 用于在 Express.js 中集成 GraphQL 的中间件。
  • graphql: GraphQL 的 JavaScript 实现。

您可以使用以下命令安装它们:

--- ------- ------- --------------- -------

创建一个 Express.js 应用程序

接下来,我们将创建一个 Express.js 应用程序。我们将创建一个名为 app.js 的文件,并编写以下代码:

----- ------- - -------------------
----- - ----------- - - ---------------------------
----- - ----------- - - -------------------

----- ------ - -------------
  ---- ----- -
    ------ ------
  -
---

----- ---- - -
  ------ -- -- ------ --------
--

----- --- - ----------

------------------- -------------
  ------- -------
  ---------- -----
  --------- -----
----

---------------- -- -- -
  -------------------- - ------- --- ------ -- --------------------------------
---

在这个文件中,我们首先导入了必要的依赖。然后,我们使用 buildSchema 函数创建了一个 GraphQL schema。这个 schema 定义了一个名为 hello 的查询,它返回一个字符串。接下来,我们定义了一个名为 root 的对象,它包含了一个名为 hello 的函数,该函数返回字符串 'Hello world!'

然后,我们创建了一个 Express.js 应用程序,并使用 graphqlHTTP 中间件将 GraphQL 集成到应用程序中。我们将 GraphQL schema 和 root 传递给中间件,并将 graphiql 选项设置为 true,以启用 GraphiQL IDE。

最后,我们将应用程序监听在端口 4000 上,并在控制台输出一个消息,以指示服务器已启动。

运行应用程序

现在,我们已经完成了应用程序的编写。我们可以使用以下命令启动服务器:

---- ------

然后,我们可以在浏览器中访问 http://localhost:4000/graphql,并在 GraphiQL IDE 中测试我们的 API。

在 GraphiQL 中,我们可以输入以下查询:

-
  -----
-

这将返回以下结果:

-
  ------- -
    -------- ------ -------
  -
-

添加更多查询

现在,我们已经成功地创建了一个简单的 GraphQL API。接下来,让我们添加更多查询。

我们将添加一个名为 user 的查询,它将返回一个用户对象,该对象包含 idname 属性。

首先,我们需要更新我们的 schema。我们将更新 type Query,以添加一个 user 查询:

----- ------ - -------------
  ---- ----- -
    ------ ------
    -------- ------ ----
  -

  ---- ---- -
    --- ---
    ----- ------
  -
---

然后,我们需要将 user 查询添加到我们的 root 对象中:

----- ---- - -
  ------ -- -- ------ --------
  ----- -- -- -- -- -
    -- ----------------
    ------ -
      ---
      ----- ----- -----
    --
  --
--

在这个示例中,我们只是返回一个硬编码的用户对象。在实际应用程序中,您需要查询数据库或其他数据源,以获取用户信息。

现在,我们已经更新了 schema 和 root,我们可以重新启动服务器,并在 GraphiQL 中测试我们的新查询。我们可以使用以下查询来测试我们的 user 查询:

-
  -------- -- -
    --
    ----
  -
-

这将返回以下结果:

-
  ------- -
    ------- -
      ----- --
      ------- ----- ----
    -
  -
-

结论

在本文中,我们介绍了如何使用 Express.js 实现 GraphQL 的 API。我们首先安装了必要的依赖,然后创建了一个 Express.js 应用程序,并使用 graphqlHTTP 中间件将 GraphQL 集成到应用程序中。我们添加了一个简单的 hello 查询,并添加了一个更复杂的 user 查询。

这只是 GraphQL 的一个简单示例。在实际应用程序中,您可能需要更复杂的 schema 和 root,以及更复杂的查询和突变。但是,本文提供了一个良好的起点,可以帮助您开始使用 Express.js 和 GraphQL 构建强大的 API。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/6725e6222e7021665e190bb3


猜你喜欢

  • React 项目调试技巧与常见问题解决方案

    React 是现在前端领域最流行的一个框架,它具有高效、可复用、易于维护等诸多优点。然而,开发过程中难免会遇到各种问题,例如组件渲染不出来、数据传递错误等等。本文将介绍一些 React 项目调试技巧和...

    6 天前
  • Fastify 如何进行单元测试

    Fastify 是一个快速、低开销且可扩展的 Node.js Web 框架。它的设计目标是提供出色的性能和开发体验。在进行 Web 应用程序开发时,单元测试是非常重要的一部分。

    6 天前
  • ECMAScript 2019 (ES10) 中的错误处理:新特性和最佳实践

    在编写 JavaScript 代码时,错误处理是非常重要的一部分。ECMAScript 2019 (ES10) 带来了一些新的特性和最佳实践,可以帮助我们更好地处理错误。

    6 天前
  • 深入剖析 GraphQL(一):GraphQL 基础

    GraphQL 是一种用于 API 的查询语言和运行时环境。它被广泛用于前端开发中,作为一种替代 RESTful API 的解决方案。GraphQL 具有很多优点,比如数据获取的精确性、可扩展性、类型...

    6 天前
  • 如何使用 CSS Flexbox 布局创建有趣的动画

    CSS Flexbox 是一种强大的布局模式,可以用于创建各种各样的动画效果。本文将介绍如何使用 CSS Flexbox 布局创建有趣的动画效果,包括基础概念、实现方法和示例代码。

    6 天前
  • Redis 优化性能的几种方法

    Redis 是一个高性能的键值存储数据库,被广泛应用于 Web 开发中,尤其是在缓存、消息队列等方面。但是,如果使用不当,Redis 也可能成为应用性能的瓶颈。本文将介绍 Redis 优化性能的几种方...

    6 天前
  • Redux 和 Mobx 的应用场景和比较

    随着前端应用的复杂性不断增加,状态管理成为了一个重要的问题。Redux 和 Mobx 都是目前比较流行的前端状态管理库。本文将介绍 Redux 和 Mobx 的应用场景、比较以及使用指导。

    6 天前
  • ES6 的 Proxy 对象在 JavaScript 中的应用及注意事项

    在 JavaScript 中,ES6 引入了 Proxy 对象,它可以让我们在访问对象的属性时拦截并自定义处理,这为我们实现一些高级的操作提供了便利。本文将介绍 Proxy 对象的基本用法和常见应用,...

    6 天前
  • 使用 Backbone.js,Marionette.js 以及 Node.js(Express.js)构建单页应用程序

    单页应用程序是一种非常流行的 Web 应用程序模式,它使用单个 HTML 页面来动态加载和更新页面内容,从而提高用户体验和性能。在本文中,我们将介绍如何使用 Backbone.js、Marionett...

    6 天前
  • Vue.js 的一些小技巧和实践

    Vue.js 是一个流行的 JavaScript 框架,它提供了一种简单、灵活、高效的方式来构建交互式的 Web 应用程序。在这篇文章中,我们将介绍一些 Vue.js 的小技巧和实践,这些技巧和实践将...

    6 天前
  • PWA 应用中音频和视频播放问题解决方式

    前言 PWA(Progressive Web App)是一种新兴的 Web 应用,它结合了 Web 应用和原生应用的优势,具有离线访问、推送通知、桌面图标等特性,使得 Web 应用在用户体验上更加接近...

    6 天前
  • 为真正无障碍的体验创建完整的 ARIA 表示法

    前言 随着互联网的快速发展,人们越来越多地依赖于网络来获取信息、交流、娱乐等。但是,对于一些视力、听力或者其他方面存在障碍的人来说,访问网站可能会面临各种困难。因此,无障碍网站设计变得越来越重要。

    6 天前
  • 解决 Kubernetes 中 Pod 网络不通的问题

    在 Kubernetes 中,Pod 网络不通的问题可能会导致应用程序无法正常运行。本文将介绍如何解决 Kubernetes 中 Pod 网络不通的问题,包括如何排查和解决网络故障、如何配置 Kube...

    6 天前
  • 使用 Fastify 进行异步编程的技巧

    Fastify 是一个快速、低开销的 Web 框架,它使用异步编程技术来提高性能。在前端开发中,异步编程是必不可少的技能,因为它可以提高应用程序的性能和响应速度。在本文中,我们将介绍使用 Fastif...

    6 天前
  • 如何使用 Django 和 Graphene 构建 GraphQL API

    GraphQL 是一种用于 API 的查询语言和运行时环境,它提供了一种更高效、强大和灵活的方式来获取和传递数据。而 Django 和 Graphene 是两个流行的 Python 库,可以帮助我们轻...

    6 天前
  • PM2 服务器崩溃后的紧急恢复

    在前端开发中,服务器的稳定性是至关重要的。然而,即使我们采取了最好的措施,服务器仍然有可能崩溃。当这种情况发生时,我们需要采取紧急措施来恢复服务器。本文将介绍如何使用 PM2 来进行服务器崩溃后的紧急...

    6 天前
  • AngularxQrcode 技术基础及使用注意事项

    前言 AngularxQrcode 是一个用于在 Angular 应用中生成二维码的开源库。它使用了 QRCode.js 库来实现二维码的生成。在本文中,我们将探讨 AngularxQrcode 的技...

    6 天前
  • Tailwind CSS 如何制作响应式滚动图示

    介绍 Tailwind CSS 是一种现代化的 CSS 框架,它提供了一组实用的 CSS 类,可以帮助开发者快速构建现代化和响应式的 Web 应用程序。在本文中,我们将介绍如何使用 Tailwind ...

    6 天前
  • Babel 编译后的代码中存在 eval 函数怎么办?

    背景 随着前端技术的不断发展,JavaScript 也变得越来越复杂。为了更好的支持 ES6 语法,我们通常使用 Babel 进行编译。但是,在 Babel 编译后的代码中,我们经常会发现存在 eva...

    6 天前
  • 学习 ESLint 的 3 个要点

    ESLint 是一个广泛使用的 JavaScript 代码检查工具,它可以帮助开发人员避免常见的代码错误和风格问题。在前端开发中,ESLint 是非常重要的工具之一。

    6 天前

相关推荐

    暂无文章