graphql变异中无法识别的参数

时间:2018-02-24 14:55:05

标签: javascript meteor graphql apollo

我目前正在关注Meteor / Apollo / GraphQL上的this tutorial,并且在使用参数/变量进行突变方面存在巨大麻烦。这是我的代码和底部的一些注释!

代码

模式

type Resolution {
    _id: String!
    name: String!
}

type Mutation {
    createResolution(name: String!): Resolution
}

解析器

import Resolutions from './resolutions'

export default {
    Query: {
        resolutions() {
            return Resolutions.find({}).fetch()
        }
    },
    Mutation: {
        createResolution(obj, args, context) {
            console.log('hey i get here')
        }
    }
}

使用突变的组件

import React, { Component } from 'react'
import gql from 'graphql-tag'
import { graphql } from 'react-apollo'

const createResolutionQuery = gql`
    mutation createResolution($name: String!) {
        createResolution(name: $name) {
            _id
        }
    }
`

class ResolutionForm extends Component {
    submitForm = () => {
        this.props
            .createResolution({
                variables: {
                    name: this.name.value
                }
            })
            .then(d => console.log('data received'))
            .catch(e => console.log(e))
    }

    render() {
        return (
            <div>
                <input type="text" ref={input => (this.name = input)} />
                <button onClick={this.submitForm}>Submit</button>
            </div>
        )
    }
}

export default graphql(createResolutionQuery, {
    name: 'createResolution'
})(ResolutionForm)

我所知道的

  • 当我尝试将查询发送到服务器时,我收到了一个http 400错误,我得到以下graphql错误:&#34;未知参数&#34;名称&#34; on field&#34; createResolution&#34;类型&#34; Mutation&#34;。&#34;
  • createResolution在我的graphiQL中可用,但在doc中没有显示任何参数。
  • 在教程中规定,更改.graphql架构不会触发流星服务器重新加载,要应用更改,我必须修改我的&#34; register-api&#34;负责制作可执行模式并使用它创建apollo服务器的文件。我做了一些虚假的改变以触发它,但它没有改变任何东西。
  • 我尝试在删除浏览器缓存后重新启动服务器,但没有结果。

所以我认为我的问题在于变异论点(我知道的精彩演绎),但我无法弄清楚错字在哪里或者我错过了什么。欢迎来自新鲜面孔的人的帮助,谢谢:)

修改

重新安装npm包解决了这个问题。

1 个答案:

答案 0 :(得分:1)

一切看起来不错我做了一个小改动,并将其作为拉取请求添加到你的github回购。

createResolution(obj, {name}, context) {
        console.log('hey i get here')
        const id = Resolutions.insert({
            name,
        })
        return Resolutions.findOne(id)
    }

在我的机器上运行我没有错误。