博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
GraphQL入门2
阅读量:6438 次
发布时间:2019-06-23

本文共 7666 字,大约阅读时间需要 25 分钟。

 

将服务器端的代码升级了一下:

var GraphQLSchema = require('graphql').GraphQLSchema;

var GraphQLObjectType = require('graphql').GraphQLObjectType;

var GraphQLString = require('graphql').GraphQLString;

var GraphQLList = require('graphql').GraphQLList;

var fetch = require('node-fetch');

require("babel-polyfill");

 

var BASE_URL = 'http://localhost:3000';

 

var persons = [

    { id: "1", first_name: "Jack", last_name: "Zhang" , department: "Depart1", friends: [1] },

    { id: "2", first_name: "Tom", last_name: "Wang" , department: "Depart2", friends: [1, 2] }

];

 

function getPersonByUrl(args, relativeURL) {

    var person = persons.find(function (item) {

        if (args.id) {

            return item.id == args.id;

        }

 

        if (args.department) {

            return item.department == args.department;

        }

       

    });

 

    return person;

 

    //fetch('${BASE_URL}${relativeURL}')

    //    .then(function (res) { return res.json() })

    //    .then(function (json) { return json.person })

}

 

 

function getFriendByPersonId(friendID) {

 

    var person = persons.find(function (item) {

        return item.id == friendID;

    });

   

    return person;

 

    //fetch('${BASE_URL}${relativeURL}')

    //    .then(function (res) { return res.json() })

    //    .then(function (json) { return json.person })

}

 

 

var PersonType = new GraphQLObjectType( {

    name: 'Person',

    description: '...',

    fields: ()=>({

        id: {

            type: GraphQLString,

            resolve : function (person) {

                return person.first_name;

            }

        },

        firstName: {

            type: GraphQLString,

            resolve : function (person) {

                return person.first_name;

            }

        },

        lastName: {

            type: GraphQLString,

            resolve : function (person) {

                return person.last_name;

            }

        },

        department: {

            type: GraphQLString,

            resolve : function (person) {

                return person.department;

            }

        },

        //email: { type: GraphQLString },

        //userName: { type: GraphQLString },

        //id: { type: GraphQLString },

        friends: {

            type: new GraphQLList(PersonType),

            resolve: function (person) {

                return person.friends.map(getFriendByPersonId);

            }

        }

    })

});

 

var QueryType = new GraphQLObjectType({

    name: 'Query',

    desription: '...',

    fields: {

        person: {

            type: PersonType,

            args: {

                id: { type: GraphQLString },

                department: { type: GraphQLString }

            },

            resolve: function (obj, args, context, info) { return getPersonByUrl(args, null); }

        }

    }

   

});

 

var GraphQLSchemaObj = new GraphQLSchema({

    query: QueryType

});

 

 

module.exports = GraphQLSchemaObj;

 

主要有以下几处更改:

  1. 将模拟的数据源persons单独提出来成为一个全局变量.
  2. 数据源中增加了department等几个属性.
  3. getPersonByUrl函数支持id和department参数.
  4. 增加了getFriendByPersonId函数用来解析friends属性.
  5. PersonType的fields属性使用了()=>来解决friends属性中使用本类型时本类型尚未初始化的问题.

 

下面是客户端的测试代码:

app.js

console.log('Hello world');

 

Arguments

//var Test1 = require('./Test1');

//Test1.Execute();

 

Alias

//var Test2 = require('./Test2');

//Test2.Execute();

 

Alias with sub-selection

//var Test3 = require('./Test3');

//Test3.Execute();

 

Fragments

//var Test4 = require('./Test4');

//Test4.Execute();

 

//Variblies

//var Test5 = require('./Test5');

//Test5.Execute();

 

//Directives

//var Test6 = require('./Test6');

//Test6.Execute();

 

具体的测试类:

Alias:

//Test2: Aliases 

 

var gRequest = require('graphql-request').request;

 

exports.Execute = function () {

 

    const query = '{'

                + '  Depart1Person: person(department: "Depart1") {'

                + '    firstName,'

                + '    lastName,'

                + '    department'

                + '  }'

                + '  Depart2Person: person(department: "Depart2") {'

                + '    firstName,'

                + '    lastName,'

                + '    department'

                + '  }'

                + '}';

       

    gRequest('http://localhost:1337/graphql/graphql', query).then(function (data) { console.log(data) });

 

};

 

               

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

运行结果如下:

{ Depart1Person: { firstName: 'Jack', lastName: 'Zhang', department: 'Depart1' },

  Depart2Person: { firstName: 'Tom', lastName: 'Wang', department: 'Depart2' } }

 

Aliases -- sub selection

//Test3: Aliases -- sub selection

 

var gRequest = require('graphql-request').request;

var util = require('util');

 

exports.Execute = function () {

 

    const query = '{'

                + '  Depart1Person: person(department: "Depart1") {'

                + '    firstName,'

                + '    lastName,'

                + '    department,'

                + '    friends'

                + '    {'

                + '     firstName,'

                + '     lastName'

                + '    }'

                + '  }'

                + '  Depart2Person: person(department: "Depart2") {'

                + '    firstName,'

                + '    lastName,'

                + '    department,'

                + '    friends'

                + '    {'

                + '     firstName,'

                + '     lastName'

                + '    }'   

                + '  }'

                + '}';

       

    gRequest('http://localhost:1337/graphql/graphql', query).then(function (data) {

        console.log(util.inspect(data, { showHidden: false, depth: null }))

    });

 

};

 

运行结果如下:

{ Depart1Person:

   { firstName: 'Jack',

     lastName: 'Zhang',

     department: 'Depart1',

     friends: [ { firstName: 'Jack', lastName: 'Zhang' } ] },

  Depart2Person:

   { firstName: 'Tom',

     lastName: 'Wang',

     department: 'Depart2',

     friends:

      [ { firstName: 'Jack', lastName: 'Zhang' },

        { firstName: 'Tom', lastName: 'Wang' } ] } }

 

Fragements:

//Test4: Fragements

 

var gRequest = require('graphql-request').request;

var util = require('util');

 

exports.Execute = function () {

 

    var query = '{'

                + '  Depart1Person: person(department: "Depart1") {'

                + '    ...personFields'

                + '  }'

                + '  Depart2Person: person(department: "Depart2") {'

                + '    ...personFields'

                + '  }'

                + '}'

                + ''

                + 'fragment personFields on Person {'

                + '  firstName,'

                + '  lastName,'

                + '  department,'

                + '  friends{'

                + '    firstName,'

                + '    lastName'

                + '  }'

                + '}';

       

    //gRequest('http://localhost:1337/graphql/graphql', query).then(function (data) { console.log(data) });

    gRequest('http://localhost:1337/graphql/graphql', query).then(function (data) {

        console.log(util.inspect(data, { showHidden: false, depth: null }))

    });

 

};

 

运行结果如下:

{ Depart1Person:

   { firstName: 'Jack',

     lastName: 'Zhang',

     department: 'Depart1',

     friends: [ { firstName: 'Jack', lastName: 'Zhang' } ] },

  Depart2Person:

   { firstName: 'Tom',

     lastName: 'Wang',

     department: 'Depart2',

     friends:

      [ { firstName: 'Jack', lastName: 'Zhang' },

        { firstName: 'Tom', lastName: 'Wang' } ] } }

Varibles:

//Test5: Variables

 

var gRequest = require('graphql-request').request;

var util = require('util');

 

exports.Execute = function () {

 

    var query = 'query PersonWithDept($dept: String) {'

            + '  person(department: $dept) {'

            + '    ...personFields'

            + '  }'

            + '}'

            + ''

            + 'fragment personFields on Person {'

            + '  firstName,'

            + '  lastName,'

            + '  department,'

            + '  friends{'

            + '    firstName,'

            + '    lastName'

            + '  }'

            + '}';

   

            var varibles =

            {

                "dept": "Depart1"

            };

       

    //gRequest('http://localhost:1337/graphql/graphql', query).then(function (data) { console.log(data) });

    gRequest('http://localhost:1337/graphql/graphql', query, varibles).then(function (data) {

        console.log(util.inspect(data, { showHidden: false, depth: null }))

    });

 

};

 

运行结果如下:

{ person:

   { firstName: 'Jack',

     lastName: 'Zhang',

     department: 'Depart1',

     friends: [ { firstName: 'Jack', lastName: 'Zhang' } ] } }   

 

Directives:

//Test6: Directives 

 

var gRequest = require('graphql-request').request;

var util = require('util');

 

exports.Execute = function () {

 

    var query = 'query PersonWithDept($dept: String, $withFriends: Boolean!) {'

                + '  person(department: $dept) {'

                + '    ...personFields'

                + '  }'

                + '}'

                + ''

                + 'fragment personFields on Person {'

                + '  firstName,'

                + '  lastName,'

                + '  department,'

                + '  friends @include(if: $withFriends){'

                + '    firstName,'

                + '    lastName'

                + '  }'

                + '}' ;

   

        var varibles1 =

        {

            "dept": "Depart1",

            "withFriends": true

        };

   

        var varibles2 =

        {

            "dept": "Depart1",

            "withFriends": false

        };

       

    //gRequest('http://localhost:1337/graphql/graphql', query).then(function (data) { console.log(data) });

    gRequest('http://localhost:1337/graphql/graphql', query, varibles1).then(function (data) {

        console.log(util.inspect(data, { showHidden: false, depth: null }))

    });

 

    gRequest('http://localhost:1337/graphql/graphql', query, varibles2).then(function (data) {

        console.log(util.inspect(data, { showHidden: false, depth: null }))

    });

 

};

 

运行结果如下:

{ person: { firstName: 'Jack', lastName: 'Zhang', department: 'Depart1' } }

{ person:

   { firstName: 'Jack',

     lastName: 'Zhang',

     department: 'Depart1',

     friends: [ { firstName: 'Jack', lastName: 'Zhang' } ] } }

 

注意客户端代码中使用了,是为了打印出json的子对象,

转载地址:http://bhzwo.baihongyu.com/

你可能感兴趣的文章
RPC框架的可靠性设计
查看>>
使用自选择创建团队
查看>>
基准测试(Benchmarks)不必消亡
查看>>
ceph 常用命令记录(完善中...)
查看>>
AppDynamics把业务交易跟踪扩展到SAP环境
查看>>
[Three.js]Three.js中文文档-自定义混合方程常数
查看>>
Kafka 处理器客户端介绍
查看>>
通过分析这段代码的进化历程,或许能够加深您对JavaScript的作用域的理解
查看>>
创建对象(一):创建与继承
查看>>
深入浅出vue1.0:Vue 实例
查看>>
XML 实体扩展攻击
查看>>
浅谈 OneAPM 在 express 项目中的实践
查看>>
kubernetes节点选择器
查看>>
Sublime Text 3初体验
查看>>
快速排序&归并排序
查看>>
将字符串转换成二维码
查看>>
AsyncTask的小分析
查看>>
使用Redis实现关注关系
查看>>
Go抓取网页数据并存入MySQL和返回json数据<三>
查看>>
MySQL复制介绍及搭建
查看>>