2018-10-17 18:19:56 -07:00
|
|
|
# React Native WebView Debugging Guide
|
|
|
|
|
|
|
|
Here are some helpful React Native WebView debugging tips.
|
|
|
|
|
|
|
|
## Debugging WebView Contents
|
|
|
|
|
|
|
|
### iOS & Safari
|
|
|
|
|
|
|
|
It's possible to debug WebView contents in the iOS simulator or on a device using Safari Developer Toolkit.
|
|
|
|
|
|
|
|
#### Steps:
|
|
|
|
|
|
|
|
1. Open Safari Preferences -> "Advanced" tab -> enable checkbox "Show Develop menu in menu bar"
|
|
|
|
2. Start app with React Native WebView in iOS simulator or iOS device
|
|
|
|
3. Safari -> Develop -> [device name] -> [app name] -> [url - title]
|
|
|
|
4. You can now debug the WebView contents just as you would on the web
|
|
|
|
|
2020-08-14 20:24:05 -07:00
|
|
|
##### Notes:
|
2018-10-17 18:19:56 -07:00
|
|
|
|
|
|
|
When debugging on device you must enable Web Inspector in your device settings:
|
|
|
|
|
|
|
|
Settings -> Safari -> Advanced -> Web Inspector
|
|
|
|
|
2020-08-14 20:24:05 -07:00
|
|
|
Also, if you don't see your device in the Develop menu, and you started Safari before you started your simulator, try restarting Safari.
|
|
|
|
|
2018-10-17 18:19:56 -07:00
|
|
|
### Android & Chrome
|
|
|
|
|
|
|
|
It's possible to debug WebView contents in the Android emulator or on a device using Chrome DevTools.
|
|
|
|
|
2018-10-30 07:47:05 -07:00
|
|
|
1. You will need to make the following change to `MainApplication.java` to enabled web contents debugging:
|
2018-10-17 18:19:56 -07:00
|
|
|
```java
|
|
|
|
import android.webkit.WebView;
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onCreate() {
|
|
|
|
super.onCreate();
|
|
|
|
...
|
|
|
|
WebView.setWebContentsDebuggingEnabled(true);
|
|
|
|
}
|
|
|
|
```
|
|
|
|
2. Start app with React Native WebView in Android emulator or Android device
|
|
|
|
3. Chrome -> DevTools -> Menu (3 dots) -> More tools -> Remote devices
|
|
|
|
4. Select your device on the left and select "Inspect" on the WebView contents you'd like to inspect
|
|
|
|
5. You can now debug the WebView contents just as you would on the web
|
|
|
|
|
2018-10-30 07:47:05 -07:00
|
|
|
data:image/s3,"s3://crabby-images/8e665/8e6652b00c15fc221eefd19d62340155aa6437b5" alt="image"
|
|
|
|
|
2018-10-17 18:19:56 -07:00
|
|
|
##### Note:
|
|
|
|
|
|
|
|
When debugging on device you must enable USB debugging in your device settings:
|
|
|
|
|
|
|
|
Settings -> System -> About Phone -> Developer options -> enable USB debugging
|