javascript - React Native 和 Apollo : Can't find variable: document

标签 javascript react-native apollo react-router-dom react-dom

我收到标题上所述的错误,但我不知道如何消除它并使我的应用程序正常运行。

我一直在尝试解决这个问题,但还没有找到解决方案。我发现与我的错误相关的唯一一件事是这个评论:“你不能在 React Native 中使用文档,你可以在菜单后面创建一个背景,然后在新闻背景上你可以隐藏它。”法耶德写的。虽然这似乎是我的答案,但我不确定如何创建那个背景。这是我的代码:

import React from 'react';
import ReactDOM from 'react-dom';
import {Route, Link, BrowserRouter as Router} from 'react-router-dom';
import news from './components/News';
import eating from './components/Eating';
import LoginForm from './components/LoginForm';
import ApolloClient from 'apollo-client';
import {ApolloProvider} from 'react-apollo';
import {HttpLink} from 'apollo-link-http';
import {InMemoryCache} from 'apollo-cache-inmemory';

const client= new ApolloClient({
  link: new HttpLink({uri:'https://api-useast.graphcms.com/v1/ck25kwqhb10bg01cx4o1i5czu/master'}),
  cache:new InMemoryCache()
})

const routing = (
  <Router>
    <Route path="/" component={LoginForm} />
    <Route path="/news" component={News} />
    <Route path="/eating" component={Eating} />
  </Router>
)


ReactDOM.render((
  <ApolloProvider client={client}>
    routing
  </ApolloProvider>
),
  document.getElementById('root')
)

这是我的 package.json 文件:

{
  "main": "node_modules/expo/AppEntry.js",
  "scripts": {
    "start": "expo start",
    "android": "expo start --android",
    "ios": "expo start --ios",
    "web": "expo start --web",
    "eject": "expo eject"
  },
  "dependencies": {
    "apollo-cache-inmemory": "^1.6.3",
    "apollo-client": "^2.6.4",
    "apollo-link-http": "^1.5.16",
    "expo": "^35.0.0",
    "graphql": "^14.5.8",
    "react": "16.8.3",
    "react-apollo": "^3.1.3",
    "react-dom": "^16.8.3",
    "react-native": "https://github.com/expo/react-native/archive/sdk-35.0.0.tar.gz",
    "react-native-web": "^0.11.7",
    "react-router-dom": "^5.1.2"
  },
  "devDependencies": {
    "babel-preset-expo": "^7.1.0"
  },
  "private": true
}

我希望能够加载我的应用程序而不会出现任何错误。

最佳答案

我解决了这个问题,我必须下载react-router-native而不是react-router-DOM。就是这样。而不是:

import React from 'react';
import ReactDOM from 'react-dom';
import {Route, Link, BrowserRouter as Router} from 'react-router-dom';
mport ApolloClient from 'apollo-client';
import {ApolloProvider} from 'react-apollo';
import {HttpLink} from 'apollo-link-http';
import {InMemoryCache} from 'apollo-cache-inmemory';

我必须这样做:

import React, {Component} from 'react';
import {Route, Link, NativeRouter as Router} from 'react-router-native';
import ApolloClient from 'apollo-client';
import {ApolloProvider} from 'react-apollo';
import {HttpLink} from 'apollo-link-http';
import {InMemoryCache} from 'apollo-cache-inmemory';

并替换类组件的 DOM 渲染。

关于javascript - React Native 和 Apollo : Can't find variable: document,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58618603/

相关文章:

javascript - 如何为 Apollo 客户端指定 GraphQL 查询并获取属性中出现适当字符串的项目

graphql - 用户特定的发布(订阅)

javascript - GraphQL:不可为空的数组/列表

javascript - 函数未将数据注册到数组中

android - 有没有办法用 React Native 避免白色闪光

ios - React-native,如何获取文件 Assets 图像绝对路径?

reactjs - 如何使用refreshControl在React Native ScrollView中刷新?

javascript - 谷歌与亚马逊 Cognito 的整合

javascript - 原型(prototype)通过标签函数获取

Javascript 对象处理困惑