发表日期: 2021-05-08 09:49:15 浏览次数:79
孟津小程序制作【孟津企业邮箱】孟津网站外包、孟津微信商城开发、孟津网店美工、孟津淘宝设计
孟津区,位于河南省中西部丘陵山区,是洛阳市市辖区之一,其东距郑州110公里,西距三门峡90公里,南与洛阳市涧西区、西工区、老城区、瀍河区、洛龙区、偃师区毗邻,北跨黄河,全区约48万人口,面积758.7平方公里、辖10个镇234个行政村(社区)是洛阳北部重要的功能片区。 [17]
2019年全区地区生产总值突破350亿元,一般公共预算收入突破18亿元,在中部六省百强县、区中跃居第80位。
2020年3月,获得全国村庄清洁行动先进县、区称号,被中央农办、农业农村部予以通报表扬,2020年7月29日,入选2019年重新确认国家卫生乡镇(县城)名单。
2021年3月18日,国务院批复同意撤销孟津县,设立洛阳市孟津区,同年4月22日正式揭牌成立;至此,黄河成为洛阳市内河。 [1]
GraphQL 既是一种用于 API 的查询语言也是一个满足你数据查询的运行时。 GraphQL 对你的 API 中的数据提供了一套易于理解的完整描述,使得客户端能够准确地获得它需要的数据,而且没有任何冗余。
GraphQL 有针对不同语言的服务端实现,以帮助开发人员搭建 GraphQL Server
。
而 gq-loader
是一个 webpack
插件,你可以认为它一针对前端项目的一种 client
端实现,它的目的是帮助前端开发同学更简便的调用 GraphQL API,它让前端开发人员在使用 GraphQL 时更加方便,像普通 js
模块一样轻松自如,使前端开发人员能在 js
文件中通过 import
或 require
导入 .gql
和 .graphql
文件,然后直接调用。 并且它还支持通过 #import
语法导入其它 .gql
文件,比如 fragments。
#import
还提供了两个别名,分别是#require
和#include
,这两个别名和#import
的用法及行为完全一致。
关注或使用 gq-loader,请访问 GitHub:github.com/Houfeng/gq-…
想更多的了解或使用 GraphQL,请移步 github.com/facebook/gr…
npm install gq-loader --save-dev
或者
yarn add gq-loader
如同其它 loader 一样,首先,我们在 webpack.config.js
中添加 gq-loader
的配置
{ test: /\.(graphql|gql)$/, exclude: /node_modules/, use: { loader: 'gq-loader' options: { url: 'Graphql Server URL' } } }
然后,我们就可以在 js
文件中通过 import
来导入 .gql
文件使用它了,我们来一个简单的示例,假设已经有一个可以工作的 Graphql Server
,那么,我们先创建一个可以查询用户的 getUser.gql
#import './fragment.gql' query MyQuery($name: String) { getUser(name: $name) ...userFields } }
可以看到,我们通过 #import
引用了另外一个 .gql
文件 fragment.gql
,在这个文件中我们描术了要返回的 user 的字段信息,这样我们就能在不同的地方「重用」它了,我们也创建一下这个文件
fragment userFields on User { name age }
好了,我们可以在 js
文件中直接导入 getUser.gql
,并且使用它查询用户了,从未如此简便,我们来看看
import getUser from './getUser.gql'; import React from 'react'; import ReactDOM from 'react-dom'; async function query() { const user = await getUser({ name: 'bob' }); console.log('user', user); } function App() { return <button onClick={query}>click</button>; } ReactDOM.render(<App />, document.getElementById('root'));
在调用 getUser
时,我们可以给函数参数向 GraphQL
传递变量,这些变量就是我们的查询参数。
默认 gq-loader
就会帮你完成 graphql 请求
,但某些场景下或许你想自已控制所有请求,如果有这样需要,我们还可以通过 request
属性来「自定义」请求,看一下示例,需要先稍微改动一下 loader 配置
{ test: /\.(graphql|gql)$/, exclude: /node_modules/, use: { loader: 'gq-loader' options: { url: 'Graphql Server URL', //指定自动请求模块路径 request: require.resolve('your_request_module_path'); } } }
在 your_request_module_path
填写自定义请求模块路径,gq-loader
将自动加载并使用对应请求模块,模块只需要改出一个「请求函数即可」,看如下自定义示例
const $ = require('jquery'); //url 是要请求的 GraphQL 服务地址 //data 是待发送的数据 //options 是自定义选项 module.exports = function(url, data, options){ //如果有需要还可以处理 options return $.post(url, data); };
其中,options
是导入 .gql
文件后「函数的第二个参数」,比如,可以这样传递 options
参数
import getUser from './getUser.gql'; async function query() { const options = {...}; const user = await getUser({ name: 'bob' }, options); console.log('user', user); }
名称 | 说明 | 默认值 |
---|---|---|
URL | 指定 graphql 服务 URL | /graphql |
request | 自定义请求函数 | 使用内建模块 |
extensions | 默认扩展名,在导入时省略扩展名时将按配置依次查找 | .gql/.graphql |
string | 指定导入模式,当为 true 时导入为字符串,而不是可执行的函数 | false |
注意,gq-loader
的 extensions
无论配置何值,在 js
中 import
时都不能省略扩展名,此选项仅作用于 .gql
文件 import
其它 .gql
文件
备案号: 苏ICP备11067224号
CopyRight © 2011 书生商友信息科技 All Right Reserved
24小时服务热线:400-111-6878 E-MAIL:1120768800@qq.com QQ:1120768800
网址: https://www.768800.com 网站建设:上往建站
关键词: 网站建设| 域名邮箱| 服务器空间| 网站推广| 上往建站| 网站制作| 网站设计| 域名注册| 网络营销| 网站维护|
企业邮箱| 虚拟主机| 网络建站| 网站服务| 网页设计| 网店美工设计| 网站定制| 企业建站| 网站设计制作| 网页制作公司|
400电话办理| 书生商友软件| 葬花网| 调温纤维| 海洋馆运营维护| 北京保安公司| 殡仪馆服务| 殡葬服务| 昌平殡葬| 朝阳殡葬|
欢迎您免费咨询,请填写以下信息,我们收到后会尽快与您联系
服务热线:400-111-6878