NextJs 使用 loadFilesSync 或 glob 加载多个文件,
NextJs load multiple files with loadFilesSync or glob,
我正在尝试使用 @graphql-tools/load-files
加载多个文件 我也尝试过使用 glob
,但也没有成功。我的文件夹结构是这样的:
/
/.next
/pages
/pages/api
/pages/api/graphql -> there I have an ApolloServer
/server
/types
/types/userTypes.ts
/types/authTypes.ts
我的想法是将 root/types 文件夹中的所有 graphql 类型作为不同的文件并在构建时合并它们:
这是 graphql.ts
文件的一部分。
import path from 'path';
import { mergeTypeDefs } from '@graphql-tools/merge';
import { loadFilesSync } from '@graphql-tools/load-files';
const typesArray = loadFilesSync(path.join(__dirname, '../../types/.*'));
console.log(typesArray);
输出为空 [] 数组。当我在没有 NextJs 的情况下尝试这个时,它按预期工作,所以我猜 NextJs 正在对文件夹结构做一些事情,但我无法弄清楚。如果有人可以提供帮助,那就太好了。提前致谢。
关于 Next JS 如何处理其文件夹结构,你是对的
将 path.join(__dirname, '../../types/.*')
替换为 path.join(process.cwd(), 'path')
,如此处 with-typescript-graphql
根据已接受的答案继续-
传递硬编码路径对我不起作用。
相反,只需使用 glob 模式。
loadFilesSync('**/*.gql')
链接示例使用 graphql-let
配置,它本质上解析为与此类似的 glob 模式。
我正在尝试使用 @graphql-tools/load-files
加载多个文件 我也尝试过使用 glob
,但也没有成功。我的文件夹结构是这样的:
/
/.next
/pages
/pages/api
/pages/api/graphql -> there I have an ApolloServer
/server
/types
/types/userTypes.ts
/types/authTypes.ts
我的想法是将 root/types 文件夹中的所有 graphql 类型作为不同的文件并在构建时合并它们:
这是 graphql.ts
文件的一部分。
import path from 'path';
import { mergeTypeDefs } from '@graphql-tools/merge';
import { loadFilesSync } from '@graphql-tools/load-files';
const typesArray = loadFilesSync(path.join(__dirname, '../../types/.*'));
console.log(typesArray);
输出为空 [] 数组。当我在没有 NextJs 的情况下尝试这个时,它按预期工作,所以我猜 NextJs 正在对文件夹结构做一些事情,但我无法弄清楚。如果有人可以提供帮助,那就太好了。提前致谢。
关于 Next JS 如何处理其文件夹结构,你是对的
将 path.join(__dirname, '../../types/.*')
替换为 path.join(process.cwd(), 'path')
,如此处 with-typescript-graphql
根据已接受的答案继续-
传递硬编码路径对我不起作用。
相反,只需使用 glob 模式。
loadFilesSync('**/*.gql')
链接示例使用 graphql-let
配置,它本质上解析为与此类似的 glob 模式。