GraphQL - Resolver
Resolver es una colección de funciones que generan respuesta para una consulta GraphQL. En términos simples, un solucionador actúa como un controlador de consultas GraphQL. Cada función de resolución en un esquema GraphQL acepta cuatro argumentos posicionales como se indica a continuación:
fieldName:(root, args, context, info) => { result }
A continuación se muestra un ejemplo de funciones de resolución:
//resolver function with no parameters and returning string
greeting:() => {
return "hello from TutorialsPoint !!!"
}
//resolver function with no parameters and returning list
students:() => db.students.list()
//resolver function with arguments and returning object
studentById:(root,args,context,info) => {
return db.students.get(args.id);
}
A continuación se presentan los argumentos posicionales y su descripción:
No Señor. | Argumentos y descripción |
---|---|
1 | root El objeto que contiene el resultado devuelto por el solucionador en el campo principal. |
2 | args Un objeto con los argumentos pasados al campo de la consulta. |
3 | context Este es un objeto compartido por todos los resolutores en una consulta en particular. |
4 | info Contiene información sobre el estado de ejecución de la consulta, incluido el nombre del campo, la ruta al campo desde la raíz. |
Formato de resultado de resolución
Los resolutores en GraphQL pueden devolver diferentes tipos de valores como se indica a continuación:
No Señor. | Argumentos y descripción |
---|---|
1 | null or undefined esto indica que el objeto no se pudo encontrar |
2 | array esto solo es válido si el esquema indica que el resultado de un campo debe ser una lista |
3 | promise los resolutores a menudo realizan acciones asincrónicas como buscar desde una base de datos o API de backend, para que puedan devolver promesas |
4 | scalar or object un resolutor también puede devolver otros valores |
Ilustración
Creemos una aplicación sencilla para entender el resolutor. Esto creará un esquema para consultar a un estudiante por identificación desde el servidor. Los datos del estudiante se almacenarán en un archivo plano y usaremos un módulo de nodo llamadonotarealdb para falsificar una base de datos y leer desde un archivo plano.
El siguiente es un proceso paso a paso para crear una aplicación simple:
Paso 1: descargue e instale las dependencias necesarias para el proyecto
Crea una carpeta llamada resolver-app. Cambie su directorio aresolver-appdesde la terminal. Posteriormente, siga los pasos 3 a 5 del capítulo Configuración del entorno.
Paso 2: crea un esquema
Agregue el archivo schema.graphql en la carpeta del proyecto resolver-app y agregue el siguiente código:
type Query {
greeting:String
students:[Student]
studentById(id:ID!):Student
}
type Student {
id:ID!
firstName:String
lastName:String
password:String
collegeId:String
}
El archivo de esquema muestra que el usuario puede consultar el saludo, los estudiantes y studentById . Para recuperar estudiantes con identificación específica, usamosdata type ID!que muestra un campo de identificador único que no acepta valores NULL. El campo de estudiantes devuelve una matriz de estudiantes y el saludo devuelve un valor de cadena simple.
Paso 3: crear un solucionador
Crea un archivo resolvers.js en la carpeta del proyecto y agregue el siguiente código:
const db = require('./db')
const Query = {
//resolver function for greeting
greeting:() => {
return "hello from TutorialsPoint !!!"
},
//resolver function for students returns list
students:() => db.students.list(),
//resolver function for studentbyId
studentById:(root,args,context,info) => {
//args will contain parameter passed in query
return db.students.get(args.id);
}
}
module.exports = {Query}
Aquí, studentById toma tres parámetros. Como se discutió en este capítulo, el studentId se puede recuperar de args; root contendrá el objeto de consulta en sí. Para devolver un estudiante específico, necesitamos llamar al método get con el parámetro id en la colección de estudiantes.
Aquí saludo, estudiantes, studentById son los solucionadores que manejan la consulta.students resolver functiondevuelve una lista de estudiantes de la capa de acceso a datos. Para acceder a las funciones de resolución fuera del módulo, el objeto Query debe exportarse usando module.exports.
Paso 4: ejecutar la aplicación
Cree un archivo server.js. Consulte el paso 8 del capítulo Configuración del entorno. Ejecute el comando npm start en la terminal. El servidor estará funcionando en el puerto 9000. Aquí, usamos GraphiQL como cliente para probar la aplicación.
Abra el navegador e ingrese la url, http://localhost:9000/graphiql. Escriba la siguiente consulta en el editor:
{
studentById(id:"S1001") {
id
firstName
lastName
}
}
El resultado de la consulta anterior es como se muestra a continuación:
{
"data": {
"studentById": {
"id": "S1001",
"firstName": "Mohtashim",
"lastName": "Mohammad"
}
}
}