首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

GraphQL+Koa2实现服务端API结合Apollo+Vue

它弥补了 RESTful API(字段冗余,扩展性差、无法聚合 api、无法定义数据 类型、网络请求次数多)等不足 注意:GraphQL 是 api 的查询语言,而不是数据库。...我们知道 REST 是一种服务 器公开数据的流行方式。当 REST 的概念被提及出来时,客户端应用程序对数据的需求相 对简单,而开发的速度并没有达到今天的水平。...比如:字段冗余,扩展性差、无法聚合 api、无法 定义数据类型、网络请求次数多 GraphQL 的出现整好弥补了 RESTful APi 的不足 使用 GraphQL 的公司 目前已经有很多的公司在使用...query:仅获取数据(fetch)的只读请求 mutation:获取数据后还有写操作的请求 新版本的GraphQL还支持subscription,这是为了处理订阅更新这种比较复杂的实时数据更新场景而设计的操作...三、Express中集成GraphQl 实现 Server API 3.1 安装mongodb数据 使用mongodb数据库演示,mac安装mongodb,brew install mongodb-community

5.1K42
您找到你想要的搜索结果了吗?
是的
没有找到

2019 简易Web开发指南

) Redux VueX NgRx Apollo (GraphQL Client) 后端渲染(server side rendering) Next.js (React) Nuxt.js (Vue) Angular...Node.Js:就算不做全栈,nodejs也将成为前端的必备技能 Python:如果除了web开发想往人工智能、机器学习、数据分析方向扩展的同学,python更合适 C#:个人很喜欢的语言,非常优雅和高效...关系型:MySQL,PostgreSQL,MS SQL NoSQL:MongoDB,Couchbase 云存储:Firebase,AWS,Azure Cosmos DB 轻量级:SQLite,NeDB...& Apollo GraphQL简而言之是一种API 查询语言(QL = query language),提供了一种革命性的API实现方式。...GraphQL是一种规范(specification)而不是实现(implementation)。而ApolloGraphQL最火的实现。更多请参考:Awesome GraphQL

2.3K41

写在 2021: 值得关注学习的前端框架和工具库

Immer[14],思路巧妙的数据不可变方案。 AngularAngular[15] 是我最近正在学的框架,在开始前我其实是拒绝的,但写了两个例子之后我觉得真香!...GraphQL-Code-Generator[48],很强大的工具,.graphql文件到语言可以直接使用的方法/类型定义,这个思想实际上各个语言都有,如Dart和Ruby等。...简单地说,你提供一个数据库,GraphQL Engine会为你基于数据库的结构(可能这就是目前都支持PostgreSQL的原因?)...,Apollo的useQuery接收的是GraphQL Document,BlitzJS中的则接收的是后端方法,其中会直接db.entity.create()这样去写数据库)。...GenQL[107],GraphQL Schema生成Query Builder,比较新所以还不怎么火,我挺看好这个库的。

4.2K10

写在2021: 值得关注学习的前端框架和工具库

Immer,思路巧妙的数据不可变方案。 AngularAngular 是我最近正在学的框架,在开始前我其实是拒绝的,但写了两个例子之后我觉得真香!...GraphQL-Yoga,Prisma团队出品,基于Apollo-Server,封装了一些特性,因此比Apollo-Server更容易上手,但功能却更强,比如原生支持文件上传这种。...GraphQL-Code-Generator,很强大的工具,.graphql文件到语言可以直接使用的方法/类型定义,这个思想实际上各个语言都有,如Dart和Ruby等。...简单地说,你提供一个数据库,GraphQL Engine会为你基于数据库的结构(可能这就是目前都支持PostgreSQL的原因?)...GenQL,GraphQL Schema生成Query Builder,比较新所以还不怎么火,我挺看好这个库的。

2.8K10

2019-Web开发技术指南和趋势

对于使用框架的大型前端项目, 你也许需要使用状态管理工具去管理你的应用级的状态 Redux(Context API) Apollo(GraphQL Client) Vuex NgRx 2.5 满足一个成熟的前端开发者条件...绝大多数觉得应用都会使用到数据库, 这里有一些选择: 关系型数据库(MySQL, PostgreSQL, MS SQL) 非关系型数据库 (MongoDB, Counchbase) 云服务 (Firebase...像React, Vue 和 Angular等端架都可以进行服务端渲染 Next.js(React) Nuxt(Vue) Angular Universal(Angular) 3.5 内容管理系统 ?...使用到了 Chromium内核和Node.js 兼容Windows, Mac & Linux 崩溃报告, 调试和性能分析 4.3 GraphQL & Apollo GraphQl是对于API的一种革命性新方法...只查询你想要的东西 前端和后端可以合作得更为顺利 查询语句非常简单且很像JSON语句 Apollo是一个发送请求到GraphQL的客户端 使用的是Gatsby静态站点生成器 4.4 TypeScript

3.3K20

2019-Web开发技术指南和趋势

对于使用框架的大型前端项目, 你也许需要使用状态管理工具去管理你的应用级的状态 Redux(Context API) Apollo(GraphQL Client) Vuex NgRx 2.5 满足一个成熟的前端开发者条件...绝大多数觉得应用都会使用到数据库, 这里有一些选择: 关系型数据库(MySQL, PostgreSQL, MS SQL) 非关系型数据库 (MongoDB, Counchbase) 云服务 (Firebase...像React, Vue 和 Angular等端架都可以进行服务端渲染 Next.js(React) Nuxt(Vue) Angular Universal(Angular) 3.5 内容管理系统 ?...使用到了 Chromium内核和Node.js 兼容Windows, Mac & Linux 崩溃报告, 调试和性能分析 4.3 GraphQL & Apollo GraphQl是对于API的一种革命性新方法...只查询你想要的东西 前端和后端可以合作得更为顺利 查询语句非常简单且很像JSON语句 Apollo是一个发送请求到GraphQL的客户端 使用的是Gatsby静态站点生成器 4.4 TypeScript

3.3K20

2017年JS 框架回顾:React 生态系统

Flux React 作为一个非完整的解决方案,其中一个尚未解决的问题就是应用程序的数据层部分。...RxJS 的使用基本是作为其它项目子依赖的驱动,特别是对于 Angular CLI。这意味着所有使用 Angular 的驱动器,都需要使用相同的 RxJS。...GraphQL GraphQL 与 React 是由 Facebook 同时开发的,但是这两者之间并没有内在的联系。GraphQL 是 Web 客户端查询服务器数据的一种方式。...GraphQL 通过名为 Relay 和 Apollo 的两个竞争库得到了普及,Relay 和 Apollo 提供了一个 Web 应用程序,用于生成 GraphQL 和管理数据流。...虽然 GraphQL 开发者使用量的绝对数还很小,但是 Apollo 的增长轨迹意味着 GraphQL 很值得开发者关注。

900100

React生态系统

React 作为一个非完整的解决方案,其中一个尚未解决的问题就是应用程序的数据层部分。...RxJS 的使用基本是作为其它项目子依赖的驱动,特别是对于 Angular CLI。这意味着所有使用 Angular 的驱动器,都需要使用相同的 RxJS。...GraphQL ? GraphQL 与 React 是由 Facebook 同时开发的,但是这两者之间并没有内在的联系。GraphQL 是 Web 客户端查询服务器数据的一种方式。...GraphQL 通过名为 Relay 和 Apollo 的两个竞争库得到了普及,Relay 和 Apollo 提供了一个 Web 应用程序,用于生成 GraphQL 和管理数据流。...虽然 GraphQL 开发者使用量的绝对数还很小,但是 Apollo 的增长轨迹意味着 GraphQL 很值得开发者关注。 React生态系统概述 ?

94730

每日前端夜话(0x04):2018年JavaScript状态调查(中)

但此处提供的所有数据仅涉及AngularAngular 随时间的流行度 ? Angular 最受喜欢的方面 ? Angular 最不受欢迎的方面 ? 哪些工具与 Angular 一起使用? ?...因此,尽管Angular在几年前丢掉了其统治地位 —— 相对而言,一旦尘埃落定,它很可能会恢复到原来的状态。 数据数据层重新组合用于传输和管理数据的所有技术。...Apollo ? 功能齐全的GraphQL缓存客户端,适用于UI框架和GraphQL服务器。 Apollo 随时间的流行度 ? Apollo 最受喜欢的方面 ? Apollo 最不受欢迎的方面 ?...数据存储在数据库中,服务器可以在其中获取数据,将其放入模板中,然后将整个数据发送到客户端。 但事情并不那么简单。 今天,程序需要知道自己如何获取数据以呈现在模板和组件中。...GraphQL用户在两年内5%上升到20%,他们选择的客户端似乎是Apollo

1.5K20

2017年 JavaScript 框架回顾 -- React生态系统

Flux React 作为一个非完整的解决方案,其中一个尚未解决的问题就是应用程序的数据层部分。...RxJS 的使用基本是作为其它项目子依赖的驱动,特别是对于 Angular CLI。这意味着所有使用 Angular 的驱动器,都需要使用相同的 RxJS。...GraphQL GraphQL 与 React 是由 Facebook 同时开发的,但是这两者之间并没有内在的联系。GraphQL 是 Web 客户端查询服务器数据的一种方式。...GraphQL 通过名为 Relay 和 Apollo 的两个竞争库得到了普及,Relay 和 Apollo 提供了一个 Web 应用程序,用于生成 GraphQL 和管理数据流。...虽然 GraphQL 开发者使用量的绝对数还很小,但是 Apollo 的增长轨迹意味着 GraphQL 很值得开发者关注。

1.2K40

GraphQL 基础实践

你可以将 GraphQL 理解成一个中间件,是连接客户端和数据库之间的一座桥梁,客户端给它一个描述,然后数据库中组合出符合这段描述的数据返回。...而 GraphQL 就是为了解决这些问题而来的,向服务端发送一次描述信息,告知客户端所需的所有数据数据的控制甚至可以精细到字段,达到一次请求获取所有所需数据的目的。...本例中我们将使用 ThinkJS 配合 MongoDB 进行搭建 GraphQL API,ThinksJS 的简单易用性会让你爱不释手!...GraphQL 的优缺点 优点 所见即所得:所写请求体即为最终数据结构 减少网络请求:复杂数据获取也可以一次请求完成 Schema 即文档:定义的 Schema 也规定了请求的规则 类型检查:严格的类型检查能够消除一定的认为失误...缺点 增加了服务端实现的复杂度:一些业务可能无法迁移使用 GraphQL,虽然可以使用中间件的方式将原业务的请求进行代理,这无疑也将增加复杂度和资源的消耗 完整源代码可以在这里 (https://github.com

12.8K20

2017JavaScript框架战报-React分战场

这一结果出乎意料,因为React作为一个局部的解决方案,本质上不如Ember和Angular这样的完整框架使用起来方便。 Flux 一个完整应用程序的另一个不通过React的部分就是数据层。...RxJS似乎是作为其他项目的子依赖项驱动的,特别是Angular CLI。这意味着所有使用Angular的驱动器都使用相同的RxJS,也被合并到其他一些流行的命令行工具中。...GraphQL 虽然它与React是同时在Facebook内部开发的,但是GraphQL与React并没有内在的联系。它只是Web客户端查询服务器数据的一种方式。...它通过名为Relay和Apollo的两个竞争库得到了一定的普及,这两个库提供用于生成GraphQL和管理数据流的Web应用程序。...首先推出的是Relay,目前正在持续成长,但是已经被半年后发布的Apollo盖过了风头。虽然绝对数量还很小,但Apollo的增长轨迹值得深入挖掘。

1K70

GraphQL 入门到实践

本文首先介绍了 GraphQL,再通过 MongoDB + graphql + graph-pack 的组合实战应用 GraphQL,详细阐述如何使用 GraphQL 来进行增删改查和数据订阅推送,并附有使用示例...试想一下你都开发完了,产品告诉你要大改一番,接口到组件结构都得改,后端也骂骂咧咧不愿配合让你好几个 API 里取数据自己组合,这酸爽 ?...GraphQL 的操作类型可以是 query、mutation 或 subscription,描述客户端希望进行什么样的操作 query 查询:获取数据,比如查找,CRUD 中的 R mutation...接收到数据: ', payload) } } } } 这里的 pubsub 是 apollo-server 里负责订阅和发布的类,它在接受订阅时提供一个异步迭代器...,然后我们将获取到并打印出 pubsub.publish 发布的 payload,这样就完成了数据订阅。

2.5K31

你不知道的 GraphQL

我们开始吧~ 目录 目标 一切Schema开始 创建一个简单的GraphQL服务端 GraphiQL,一个Graphql领域的postman 编写Resolvers 处理数据依赖关系 对接真正的数据库...,提供支撑,可以实现单一请求次数下就可以获取足够的数据。...啊哈~ 你可以在graphql.org网站找到关于GraphQL执行机制的描述[15]。 对接真正的数据库 在真实项目中,resolver需要和数据库或其它API打交道来获取数据。...现在{ Tweets { Author { username } }查询只会执行2次查询请求:一次用来获取Tweets数据,一次用来获取所有需要的Tweet.Author数据!...可以Apollo: GraphQL Input Types And Client Caching[30]了解更多细节 Persisted Queries:这个主题会在后续的文章中涉及。

3.3K20

塔荐 | 2018 年最值得关注的 JavaScript 趋势

尽管Facebook从未在这场游戏中领先过,并且在创新的势头上无法与Vue匹敌,但在工具使用、代码切割、路由以及状态管理方面, React加上Next.js能让你在体验上跟Vue接近许多 ,此外还能让你获得大规模的...Redux、Relay Modern 以及 Apollo Redux 是一直很火的 Dan Abramov / Andrew Clark 项目,后来有迅速成为React状态管理和数据抓取的首选解决方案...但GraphQL改变了现状,主要是在数据抓取方面。...我们现在有了 Relay Modern (Facebook开发)和Apollo,让你可以比Redux更高效地抓取并传递GraphQL数据到React应用的GraphQL客户端框架。...这两个框架在2017年均站稳了脚跟,也都是JavaScript到原生应用很好的解决方案。

1.5K80

GraphQL到底怎么使?看看智联前端团队技术沉淀

中间是主要由 Schema 和 Resolver 组成的 GraphQL 引擎服务。 右侧是 Resolver 对接的数据源。 仅仅有客户端是无法工作的。...初识 GraphQL 的实现能让客户端获取以结构化的方式,服务端结构化定义的数据中只获取想要的部分的能力。 符合 GraphQL 规范的实现我称之为 GraphQL 引擎。...这里的服务端不仅指网络服务,用 GraphQL 作为中间层数据引擎提供本地数据获取也是可行的,GraphQL 规范并没有对数据源和获取方式加以限制。...apollo:提供了开箱即用的完整的 Node.js 服务;提供了拼接 Schema(本地、远端)的方法,使 GraphQL 服务拆分成为可能;提供了客户端可用的数据获取管理工具。...所以也会 GraphQL 的开发者和两者间的角度谈谈成本和收益。 BFF:GraphQL 可以完成数据聚合、字段转换这种符合 BFF 特征的功能,提供了一种 BFF 的实现选择。

2.3K20
领券