流程

时间:2017-07-17 16:07:14

标签: javascript react-native flowtype fetch-api flow-typed

我正在努力使用fetch API和反应原生应用程序中的flowjs实现。

使用Nuclide,我可以看到我用来从远程API获取数据的fetch函数不包含在Flow ...

是的,如果我对99%的代码进行监控,但仍然没有什么大不了的。我想了解发生了什么。

我已经安装了flow-typed。我为我的fetch创建了一个存根,我可以在flow-typed / npm / fbjs_vx.x.x.x中看到它,这里是:

declare module 'fbjs/lib/fetch' {
  declare module.exports: any;
}

我也尝试下载替代的ponyfill或polyfill,以便在没有任何成功的情况下覆盖该行。

如果没有libdef,我怎么说" fetch取一个字符串作为参数并返回一个promise#34;流动?

感谢您的帮助

更新

这是package.json

{
  "name": "BeerOmatic",
  "version": "0.0.1",
  "private": true,
  "scripts": {
    "start": "node node_modules/react-native/local-cli/cli.js start",
    "test": "jest",
    "flow": "flow",
    "android": "ENVFILE=.env.dev react-native run-android"
  },
  "dependencies": {
    "eslint-config-airbnb-flow": "^1.0.2",
    "eslint-plugin-flowtype": "^2.35.0",
    "fetch-ponyfill": "^4.1.0",
    "flow-typed": "^2.1.2",
    "react": "16.0.0-alpha.12",
    "react-native": "0.46.3",
    "react-native-config": "^0.5.0",
    "react-native-fetch-polyfill": "^1.1.2",
    "react-native-navigation": "^1.1.136",
    "react-redux": "^5.0.5",
    "redux": "^3.7.2",
    "redux-logger": "^3.0.6",
    "redux-thunk": "^2.2.0",
    "whatwg-fetch": "^2.0.3"
  },
  "devDependencies": {
    "babel-cli": "^6.24.1",
    "babel-eslint": "^7.2.3",
    "babel-jest": "20.0.3",
    "babel-preset-flow": "^6.23.0",
    "babel-preset-react-native": "2.1.0",
    "eslint": "^3.19.0",
    "eslint-config-airbnb": "^15.0.2",
    "eslint-plugin-import": "^2.7.0",
    "eslint-plugin-jsx-a11y": "^5.1.1",
    "eslint-plugin-react": "^7.1.0",
    "eslint-plugin-react-native": "^2.3.2",
    "flow-bin": "^0.50.0",
    "jest": "20.0.4",
    "react-test-renderer": "16.0.0-alpha.12"
  },
  "jest": {
    "preset": "react-native"
  }
}

1 个答案:

答案 0 :(得分:1)

嗯......大部分时间,答案都在文档中......

  

要声明一个应该可以在整个项目中访问的全局函数,请在libdef文件中使用declare函数语法:

     

流类型/ myLibDef.js

     

声明函数foo(a:number):string;   这告诉Flow项目中的任何代码都可以引用foo全局函数,并且该函数接受一个参数(一个数字)并返回一个字符串。

所以我补充说

declare function fetch (a: string): Promise;

到我的flow-typed文件夹根目录下的全新myLibDef.js文件。 然后令人惊讶的是,我不得不将它添加到我的.flowConfig(在libs部分)。我很确定它是自动的但是......好吧...... 无论如何现在获取被覆盖! \ 0 /