отредактировать собственный загружаемый пакет javascript 100% застрял

когда я пытаюсь выполнить npm start, он работает нормально, но когда я пытаюсь запустить свое приложение на expo, процесс идет до 100%, и после этого ничего не происходит. Я не понимаю, что такое точная проблема. У меня есть следующие вещи в package.json...., пожалуйста, помогите мне решить эту проблему.

{
  "name": "ProMeeting",
  "version": "0.1.0",
  "private": true,
  "devDependencies": {
    "jest-expo": "~29.0.0",
    "react-native-scripts": "^1.14.0",
    "react-test-renderer": "16.3.1"
  },
  "main": "./node_modules/react-native-scripts/build/bin/crna-entry.js",
  "scripts": {
    "start": "react-native-scripts start",
    "eject": "react-native-scripts eject",
    "android": "react-native-scripts android",
    "ios": "react-native-scripts ios",
    "test": "jest"
  },
  "jest": {
    "preset": "jest-expo"
  },
  "dependencies": {
    "@babel/preset-react": "^7.0.0-beta.56",
    "expo": "^29.0.0",
    "firebase": "^5.3.1",
    "native-base": "^2.7.2",
    "react": "16.3.1",
    "react-native": "^0.55.4",
    "react-native-firebase": "^4.3.8",
    "react-native-vector-icons": "^5.0.0",
    "react-navigation": "^2.11.2"
  }
}

Ответы

Ответ 1

Кажется, есть много причин, почему это могло произойти. Я попытался запустить другие приложения на моем симуляторе, перезапустил свой симулятор и даже попытался удалить папки сборки и перестроить с нуля, но ни один из этих подходов не решил проблему.

В конечном итоге сработал restarting the React Native Debugger который все время работал в фоновом режиме.

Ответ 2

response-native-firebase часто вызывает ту же проблему.

Ниже приведено официальное руководство по интеграции своих реактивных баз. https://rnfirebase.io/docs/v5.xx/installation/ios

Б) В начале метода didFinishLaunchingWithOptions: (NSDictionary *) launchOptions добавьте следующую строку:

[FIRApp настроить]; "Рекомендуется добавить строку в метод ДО ДО создания RCTRootView. В противном случае инициализация может произойти после того, как она уже потребовалась в вашем коде JavaScript, что приведет к тому, что приложение не инициализирует исключения".

У вас есть GoogleService-Info.plist? Вы установили? Аппаратное обеспечение> Удалить все содержимое и настройки в симуляторе?

Ответ 3

В моем случае мой код работал в Android, но не в симуляторе iOS.

SplashScreen.preventAutoHide(); была проблема.

Я дважды вызвал метод App.js и Main.js соответственно.

После удаления в App.js все заработало.

(Я думаю, что restarting the React Native Debugger также помог)

Ответ 4

Вам нужно установить Android Emulator, например, с помощью Android Studio или Genymotion. Затем создайте виртуальное устройство Android. После этого запустите свое виртуальное устройство и запустите

npm run android

После этого Expo начнется на вашем устройстве.

Ответ 5

Вы должны попробовать создать новый проект, отвечающий за реакцию, и перенести ваши файлы в новый проект, а затем попробовать запустить его снова, эта проблема возникает, когда файлы сборки отсутствуют

Ответ 6

В моем случае это всегда происходило, когда я включал удаленную отладку JS. Пакет JS загрузился бы до 100%, но затем приложение зависло. Не удалось подключиться к React Native Debugger с сообщением об ошибке Another debugger is already connected.

Попробовав все виды вещей (сброс кеша, перезапуск Metro Builder, перезапуск симулятора) без какой-либо удачи, я вспомнил, что единственным "другим отладчиком", который я когда-либо использовал, был Chrome Devtools, поэтому я вышел из Chrome, и сразу все снова заработало.

Оказывается, даже несмотря на то, что я закрыл вкладку Chrome, где я отлаживал приложение, некоторый фоновый процесс в Chrome все еще был присоединен в качестве отладчика к приложению (также после перезагрузок симулятора). Затем он достиг некоторой точки останова или исключения при запуске, поэтому остановился, и все, что я мог видеть, было сообщение Downloading Javascript bundle 100%.

Ответ 7

Хорошо, этот пост старый, но давайте рассмотрим, как я решил эту проблему для себя:

> install yarn

> run: yarn remove react-native

> run: yarn add react-native

> run: react-native run-android