java - native react :android.view.WindowManager $BadTokenException

标签 java android reactjs react-native

我有一个错误,我不知道从哪里开始。尝试更新 react-native 版本 - 但没有成功..

环境

react-native-cli: 2.0.1
react-native: 0.54.2

生产构建

该应用已构建并发布到 Google Play 商店。所以它是编译的生产版本。认为这可能是模块的问题..但不太确定..

这是我在主要组件中的导入

import React, { Component } from 'react'
import { View, Modal, Text, TextInput, StyleSheet } from 'react-native'
import { KeyboardAwareScrollView } from 'react-native-keyboard-aware-scroll-view'

全栈

java.lang.RuntimeException: 

  at com.facebook.react.bridge.ReactContext.handleException (ReactContext.java:313)

  at com.facebook.react.bridge.GuardedRunnable.run (GuardedRunnable.java:23)

  at android.os.Handler.handleCallback (Handler.java:739)

  at android.os.Handler.dispatchMessage (Handler.java:95)

  at android.os.Looper.loop (Looper.java:158)

  at android.app.ActivityThread.main (ActivityThread.java:7225)

  at java.lang.reflect.Method.invoke (Native Method)

  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:1230)

  at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1120)
Caused by: android.view.WindowManager$BadTokenException: 

  at android.view.ViewRootImpl.setView (ViewRootImpl.java:849)

  at android.view.WindowManagerGlobal.addView (WindowManagerGlobal.java:337)

  at android.view.WindowManagerImpl.addView (WindowManagerImpl.java:91)

  at android.app.Dialog.show (Dialog.java:350)

  at com.facebook.react.views.modal.ReactModalHostView.showOrUpdate (ReactModalHostView.java:256)

  at com.facebook.react.views.modal.ReactModalHostManager.onAfterUpdateTransaction (ReactModalHostManager.java:107)

  at com.facebook.react.views.modal.ReactModalHostManager.onAfterUpdateTransaction (ReactModalHostManager.java:28)

  at com.facebook.react.uimanager.ViewManager.updateProperties (ViewManager.java:35)

  at com.facebook.react.uimanager.NativeViewHierarchyManager.createView (NativeViewHierarchyManager.java:233)

  at com.facebook.react.uimanager.UIViewOperationQueue$CreateViewOperation.execute (UIViewOperationQueue.java:153)

  at com.facebook.react.uimanager.UIViewOperationQueue$1.run (UIViewOperationQueue.java:816)

  at com.facebook.react.uimanager.UIViewOperationQueue.flushPendingBatches (UIViewOperationQueue.java:929)

  at com.facebook.react.uimanager.UIViewOperationQueue.access$2100 (UIViewOperationQueue.java:47)

  at com.facebook.react.uimanager.UIViewOperationQueue$2.runGuarded (UIViewOperationQueue.java:887)

  at com.facebook.react.bridge.GuardedRunnable.run (GuardedRunnable.java:21)

更新

我在 3 个不同的地方使用模态。

const Credits = ({ display, toggle }) => (
  <View>
    <TouchableOpacity
      style={[styles.button, styles.info]}
      onPress={() => toggle()}
    >
      <Icon name="question" size={30} color="#000" />
    </TouchableOpacity>

    {display && (
      <Modal
        animationType="slide"
        transparent={true}
        onRequestClose={() => toggle()}
      >
        <View style={styles.card}>
          <ScrollView>
            { ... code ...  }
          </ScrollView>
          <TouchableOpacity
            style={[styles.button, styles.close]}
            onPress={() => toggle()}
          >
            <Icon name="close" size={30} color="#000" />
          </TouchableOpacity>
        </View>
      </Modal>
    )}
  </View>
)

不知道是不是因为我用了{ display && <Modal .../> }逻辑而不是使用 Prop visible={display} ???

非常感谢任何帮助!

最佳答案

因为 React native 是异步工作的;在从 React Native 获取结果之后和更新任何 UI 之前,检查 activity.isFinishing() 并且如果 Activity 正在完成则不要更改 UI

另一种解决方案是将 Activity 状态保存在 onResume() 和 onPause() 中的某个实例变量中,然后在从 React 获取结果时检查 Activity 状态,如果 Activity 恢复,则只显示结果,但如果您 Activity 暂停,将 React 的结果保存在某处,并在 Activity 的 onResume() 方法中显示结果。 另外,不要忘记检查上面的生命周期,以向用户显示 React 的任何错误。来自 React 的任何 Android UI 更新都应考虑 Android Activity 生命周期。

void onResume(){
    super.onResume();
    activityResumed = true;
    if(showResultsOnResume){
        showResultsOnResume = false;
       //you have saved results from react waiting to show, show it here
     }
}
void onPause(){
       super.onPause();
       activityResumed = false;
}

// use this method to update any UI from React
void onReactResult(/*Results or Errors from React*/){ 
       if(activityResumed){
           // show the result
       }else{
           showResultsOnResume = true;
           // save result
       }
}

关于java - native react :android.view.WindowManager $BadTokenException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49495170/

相关文章:

reactjs - 可触摸的不透明度标题 React Native

android - 带圆边的按钮动态背景颜色

Android 蓝牙 accept()/connect() 与已经配对的设备

android - 是否可以从同一网络上的另一台设备访问部署在 Android 手机上的 HTTP 服务器?

reactjs - 图片未加载但路径正确

javascript - react : how to filter an array of objects in props

java - Eclipse:调试每个循环时的迭代计数

java - 将外部库导入到 eclipse - Android

Java 代码审查 : Merge sorted lists into a single sorted list

java - 直接支持JSR-330注入(inject)的嵌入式web容器?