首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >@genType只生成一个类型

@genType只生成一个类型
EN

Stack Overflow用户
提问于 2020-02-27 07:08:50
回答 1查看 113关注 0票数 1

在将ReasonML添加到React本机typeScript代码基之后,我发现@genType只生成了一个类型,尽管BuckleScript成功地转换了这两个函数。如何解决这个问题?

reasonSum.re

代码语言:javascript
复制
[@genType]
let reasonSum = (a, b) => a + b;
let reasonSum2 = (a, b) => a + b;

reasonSum.gen.tsx

代码语言:javascript
复制
/* TypeScript file generated from reasonSum.re by genType. */
/* eslint-disable import/first */

// tslint:disable-next-line:no-var-requires
const Curry = require('bs-platform/lib/es6/curry.js');

// tslint:disable-next-line:no-var-requires
const reasonSumBS = require('./reasonSum.bs');

export const reasonSum: (a:number, b:number) => number = function (Arg1: any, Arg2: any) {
  const result = Curry._2(reasonSumBS.reasonSum, Arg1, Arg2);
  return result
};

bsconfig.json

代码语言:javascript
复制
{
  "name": "reason-in-react-typescript",
  "sources": [
    {
      "dir": "./reason",
      "subdirs": true
    }
  ],
  "package-specs": [
    {
      "module": "es6-global",
      "in-source": true
    }
  ],
  "bs-dependencies": [
    "@glennsl/bs-json",
    "bs-fetch"
  ],
  "suffix": ".bs.js",
  "namespace": true,
  "refmt": 3,
  "gentypeconfig": {
    "language": "typescript",
    "module": "es6",
    "importPath": "relative",
    "shims": {
      "Js": "Js",
      "React": "ReactShim",
      "ReactEvent": "ReactEvent",
      "ReasonPervasives": "ReasonPervasives",
      "ReasonReact": "ReactShim"
    },
    "debug": {
      "all": false
    },
    "exportInterfaces": false
  }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-02-27 07:49:23

通常,附加到单个项的属性只适用于该项。可以通过不将属性与特定项关联起来来使属性独立,这可能被解释为与包含在其中的模块相关联,但我认为genType不支持这一点。相反,您似乎必须向要导出的每个项添加一个属性:

代码语言:javascript
复制
[@genType]
let reasonSum = (a, b) => a + b;
[@genType]
let reasonSum2 = (a, b) => a + b;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60427937

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档