欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

GraphQL入门2

发布时间:2024/4/13 编程问答 43 豆豆
生活随笔 收集整理的这篇文章主要介绍了 GraphQL入门2 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

 

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

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;

 

主要有以下几处更改:

  • 将模拟的数据源persons单独提出来成为一个全局变量.
  • 数据源中增加了department等几个属性.
  • getPersonByUrl函数支持id和department参数.
  • 增加了getFriendByPersonId函数用来解析friends属性.
  • 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的子对象,

    总结

    以上是生活随笔为你收集整理的GraphQL入门2的全部内容,希望文章能够帮你解决所遇到的问题。

    如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。