我正在从事一个项目,在这个项目中,我希望使用gql2ts库从graphql生成类型。在gql-2-ts文件中,我为glob使用了一个名称空间导入,但是类型记录显示了预期的错误。然后,我将导入更改为默认导入,但它仍然选择命名空间对象而不是函数。
gql-2-ts.ts
import fromQuery from '@gql2ts/from-query'
import DEFAULT_OPTIONS from '@gql2ts/language-typescript'
import * as fs from 'fs-extra'
import * as  G from 'glob'  // namespace import 
// import  G from 'glob'    // default import 
import * as graphql from 'graphql'
import * as path from 'path'
import {promisify} from 'util'
const NO_OF_DIRECTORIES_OFFSET = 2
const {Kind} = graphql
const glob = promisify(G)
const readFile = promisify<string, Buffer>(fs.readFile)
const writeFile = <(file: string, content: string) => void>(
  promisify(fs.writeFile)
)
const removeWhiteSpace = (q: string) =>
  q.replace(/\n/g, '').replace(/\s\s*/g, ' ')
const identity = <T>(arg: T): T => arg
const main = async () => {
  const {data} = await fs.readJSON('graphql.schema.json')
  const args = process.argv.slice(2)
  for (let i = 0; i < args.length; i++) {
    const cwd = path.resolve(process.cwd(), args[i])
    const files = await glob('**/*.graphql', {
      cwd: cwd
    })
    const allEnumsArray = await Promise.all(
      files
        .map((i) => path.resolve(cwd, i))
        .map((path) => compileFile(path, data, args[i]))
    )
    const enumsData: EnumData = {}
    allEnumsArray.forEach((enumsMap) => {
      if (enumsMap) {
        Object.keys(enumsMap).forEach((enumName) => {
          enumsData[enumName] = enumsMap[enumName]
        })
      }
    })
    const allEnums = Object.keys(enumsData)
    await Promise.all(
      allEnums.map((enumName) =>
        writeEnumsFile(enumName, enumsData[enumName], args[i])
      )
    )
    console.log(`Compiled ${files.length} files inside ${args[i]}`) // tslint:disable-line
  }
}
main().catch((err) => {
  console.error(err) // tslint:disable-line
  process.exit(1)
})这是我的tsconfig文件。
{
  "compilerOptions": {
    "module": "commonjs",
    "target": "es5",
    "skipLibCheck": true,
    "jsx": "react",
    "esModuleInterop": true,
    "downlevelIteration": true,
    "allowSyntheticDefaultImports": true,
    "lib": [
      "dom", "dom.iterable"
    ]
  },
  "exclude": ["node_modules"]
}在名称空间导入的情况下,我将得到以下错误
在使用默认导入时
。From_query_1.default(.).map不是函数
因为它选择了命名空间对象。
我找到了一位与此相关的医生,但没有多大帮助。
https://www.typescriptlang.org/docs/handbook/release-notes/typescript-2-7.html
注意:新的行为是在一个标志下添加的,以避免对现有代码库进行不必要的中断。我们强烈建议将其应用于新的和现有的项目。对于现有项目,需要将名称空间导入(导入*作为来自“express”的表示;express();)转换为默认导入(从“express”导入快件;express();)。
发布于 2021-04-15 09:08:10
我解决了问题。在一些库中存在版本冲突。将这些版本用于下列库
并使用默认导入,它将工作。保持帖子,以防有人遇到同样的错误。
https://stackoverflow.com/questions/67093374
复制相似问题