搜索

首页  >  问答  >  正文

在nuxt.js中导入GraphQL文件。

<p>所以我正在导入由postgraphile生成的模式,但它没有正确加载。</p><p>这是输出的类型:</p><p><br /></p> <pre class="brush:php;toolbar:false;">definitions: Array(44) [ {…}, {…}, {…}, … ] kind: "Document" loc: Object { start: 0, end: 26188, source: {…} }</pre> <p>我尝试了各种代码变化来加载我的查询allUsers。</p> <pre class="brush:php;toolbar:false;"><script setup> import Schema from '@/graphql/schema.gql' console.log('Query', Schema.valueOf('allUsers')) const { data } = await useAsyncQuery(Query) </script></pre> <p><br /></p>
P粉754473468P粉754473468526 天前575

全部回复(1)我来回复

  • P粉807471604

    P粉8074716042023-07-29 00:04:48

    valueOf方法不适用于此目的。GraphQL模式文档无法通过键值对访问方法直接访问其查询、变异或订阅。、

    首先,请确保您已在项目中安装了graphql-tag包:

    npm install graphql-ta

    在schema.gql中定义您的查询:


    query AllUsers {
      allUsers {
        nodes {
          id
          name
          # other fields...
        }
      }
    }

    在组件中导入并使用AllUsers查询:

    <script setup>
    import { useQuery } from "@vue/apollo-composable";
    import { loader } from "graphql.macro";
    
    const Schema = loader('@/graphql/schema.gql');
    
    const { result } = useQuery({
      query: Schema.AllUsers
    });
    
    // Here, 'result' will contain your fetched data when available.
    </script>

    希望有用

    回复
    0
  • 取消回复