React Native: Uncaught (in promise) 错误: DeltaPatcher 在初始化时应该收到一个基础 Bundle
Posted
技术标签:
【中文标题】React Native: Uncaught (in promise) 错误: DeltaPatcher 在初始化时应该收到一个基础 Bundle【英文标题】:React Native: Uncaught (in promise) Error: DeltaPatcher should receive a base Bundle when being initialized 【发布时间】:2019-10-26 11:49:28 【问题描述】:我最近在http://localhost:8081/debugger-ui/ 中遇到了这条错误消息,上面写着:
Uncaught (in promise) Error: DeltaPatcher should receive a base Bundle when being initialized
at DeltaPatcher.applyDelta
at deltaUrlToBlobUrl
at async getBlobUrl
at async WebSocket.ws.onmessage
applyDelta
deltaUrlToBlobUrl
async function (async)
ws.onmessage
当我尝试从模拟器中打开我的 React Native 应用程序时会发生此错误,虽然 index.ios.js
文件构建成功,但应用程序仍然卡在启动屏幕上并出现上述错误。
我不知道它指的是什么,从哪里开始调试,或者这个DeltaPatcher
来自什么包。
就我在收到此错误之前所做的事情而言,这就是我正在做的事情:
react-native 选项卡视图的包修复
必须删除 npm-shrinkwrap.json 才能运行 npm install
必须卸载并重新安装 react-native-splash-screen 才能通过 使用 xcode 构建失败
必须在 Sentry 中创建具有 project:write 权限的新 auth.token 克服 403 错误
从项目中手动完全删除 Instabug
修复 Spinkit 和 alerts.filter
错误
在此之后应用程序正常工作,但后来我不得不 解决 Xcode 中的以下错误。
删除了与8CBD27422B744FC9C0407AA3
相关的所有引用PhaseScriptExecution
错误
将配置重构为以前的版本以消除 AppReactNativeCrashed 错误
修改 Podfile 配置以反映 AppCenter 升级
删除 instabug 参考和 spinkit 参考
然后我想起我安装了 Metro 版本 29 以尝试解决另一个问题。所以我完全删除了 Metro 作为一个包,但并没有解决它。
我正在运行的脚本是react-native run-ios
,这是我的package.json
文件:
"scripts":
"start": "nps",
"test": "nps setup && nps test",
"build": "nps build",
"prepare": "nps patcher",
"setup": "nps setup && nps appcenter",
"react-devtools": "react-devtools"
,
"dependencies":
"appcenter": "2.0.0",
"appcenter-analytics": "2.0.0",
"appcenter-crashes": "2.0.0",
"axios": "0.16.2",
"date-fns": "^1.29.0",
"lodash": "4.17.4",
"moment": "2.20.1",
"payment": "2.3.0",
"prop-types": "15.6.0",
"react": "16.8.3",
"react-native": "0.59.9",
"react-native-autoheight-webview": "0.6.1",
"react-native-calendar-events": "1.6.1",
"react-native-device-info": "0.21.5",
"react-native-exception-handler": "2.8.9",
"react-native-image-progress": "1.0.1",
"react-native-immediate-phone-call": "1.0.0",
"react-native-keyboard-aware-scroll-view": "0.4.4",
"react-native-keyboard-manager": "4.0.13-12",
"react-native-material-buttons": "0.5.0",
"react-native-material-dropdown": "0.5.2",
"react-native-material-tabs": "3.5.0",
"react-native-material-textfield": "0.10.0",
"react-native-onesignal": "3.0.7",
"react-native-popup-menu": "0.8.3",
"react-native-sentry": "0.32.0",
"react-native-size-matters": "0.1.0",
"react-native-splash-screen": "3.0.6",
"react-native-svg": "6.3.1",
"react-native-swipe-view": "https://github.com/jjd314/react-native-swipe-view",
"react-native-tab-view": "1.3.2",
"react-native-vector-icons": "6.1.0",
"react-native-xcode-packager": "0.1.0",
"react-navigation": "1.5.11",
"react-redux": "5.0.6",
"reactotron-react-native": "3.5.0",
"reactotron-redux": "3.1.0",
"recompose": "0.26.0",
"redux": "4.0.1",
"redux-thunk": "2.2.0",
"replace-in-file": "3.1.1"
,
"devDependencies":
"@babel/core": "7.4.5",
"@babel/plugin-proposal-optional-chaining": "7.2.0",
"@babel/runtime": "7.4.5",
"async": "2.6.0",
"babel-cli": "6.24.1",
"babel-eslint": "8.0.2",
"babel-jest": "23.0.0",
"babel-plugin-module-resolver": "3.0.0",
"babel-preset-env": "1.4.0",
"babel-preset-flow": "6.23.0",
"babel-preset-stage-2": "6.24.1",
"babel-watch": "2.0.6",
"chalk": "1.1.3",
"detox": "8.2.3",
"eslint": "4.12.0",
"eslint-import-resolver-babel-module": "4.0.0-beta.3",
"eslint-plugin-import": "2.8.0",
"eslint-plugin-prettier": "2.3.1",
"eslint-plugin-react": "7.5.1",
"flow-bin": "0.46.0",
"fs-extra": "5.0.0",
"jest": "23.0.0",
"metro-react-native-babel-preset": "0.54.1",
"nps": "5.7.1",
"nps-utils": "^1.5.0",
"patch-package": "5.1.1",
"postinstall-prepare": "1.0.1",
"prettier": "1.8.2",
"prettier-eslint": "8.2.2",
"react-devtools": "3.6.1",
"react-test-renderer": "16.2.0",
"redux-mock-store": "1.3.0",
"yargs": "8.0.1"
,
"jest":
"preset": "react-native",
"setupTestFrameworkScriptFile": "./jest-setup.js",
"transformIgnorePatterns": [
"/node_modules/(?!parse)/"
],
"unmockedModulePathPatterns": [
"react",
"react-navigation",
"axios",
"redux",
"redux-thunk",
"lodash",
"date-fns"
],
"verbose": true
,
"detox":
"configurations":
"ios.sim.debug":
"binaryPath": "ios/build/Build/Products/Debug-iphonesimulator/NFIBEngage.app",
"build": "xcodebuild -workspace ios/NFIBEngage.xcworkspace -configuration Debug -scheme NFIBEngage -sdk iphonesimulator -derivedDataPath ios/build",
"type": "ios.simulator",
"name": "iPhone 6"
,
"test-runner": "jest"
【问题讨论】:
github.com/facebook/react-native/issues/… @MedetTleukabiluly,是的,我看了一下。在我把它贴在这里之前,我用谷歌搜索了这个错误。 如果你只是关闭 debugger-ui,或者重新安装插件会怎样 @MedetTleukabiluly,错误似乎与地铁有关。我最初在这个应用程序上没有 Metro 包,所以我删除了它,但还没有修复它。我将尝试删除节点模块并在没有 Metro 的情况下重新安装所有内容。 我能够解决我的问题,帮助我的真正日志在 Metro 日志中,它与 Firebase 相关 【参考方案1】:好的,所以在我删除 Metro 版本 29 后,我只是不断重复运行这些命令:
rm -rf node_modules && npm install && npm run setup && react-native run-ios
现在它通过启动屏幕启动另一个但更熟悉的错误。
【讨论】:
可以分享运行脚本吗?你能分享你的 package.json 文件吗? @simo,感谢您的关注。我已包含您要求的信息。我目前正在获得一个继续崩溃的应用程序,崩溃意味着它会打开启动屏幕并停留在那里。除了它的某个包不适用于 RN 的 0.59.9 版之外,我对此束手无策。这只是在ios
方面,在android
方面,我收到此错误:Task 'installDebug' not found in project ':app'. Some candidates are: 'installDevDebug'
@simo,所以我在上面的 cmets 中发布的内容正在发生,不管现在我的项目成功创建了一个以前没有的 main.jsbundle
文件,因为我更改了 index.ios.js
到index.js
感谢@Daniel,希望您的问题能够得到解决
@simo,谢谢,我愿意接受建议,或者如果您可以与任何可能有想法的人分享这篇文章。以上是关于React Native: Uncaught (in promise) 错误: DeltaPatcher 在初始化时应该收到一个基础 Bundle的主要内容,如果未能解决你的问题,请参考以下文章
如何解决 index.js:9 Uncaught TypeError:无法读取未定义的属性“setWallpaper”?
我需要下载 react-navigation 并使用命令 npm i @react-navigation/native 并显示错误
React Uncaught ReferenceError:未定义缓冲区
使用 TypeScript 在 React Native 上传递 refs:(属性) React.MutableRefObject<null>.current: null Object i