Go to file
Julien Eluard b1cbf077e0 chore(docs): Custom Android: Reflect migration to react-native-webview project (#347)
Doc is now up-to-date with latest `react-native-webview` changes
2019-02-15 11:56:55 +01:00
.circleci chore(ci and npm): Setup CircleCI and semantic-release 2018-10-17 14:54:44 +02:00
android feat(toggle scroll bar): added new props showsVerticalScrollIndicator / showsHorizontalScrollIndicator (#250) 2019-02-12 14:47:24 +01:00
bin Added starter setup script 2018-08-15 21:09:05 -07:00
docs chore(docs): Custom Android: Reflect migration to react-native-webview project (#347) 2019-02-15 11:56:55 +01:00
ios fix(WKWebView): resolved crash with WebKit on iOS 9.x. (#342) 2019-02-14 15:18:15 +01:00
js feat(toggle scroll bar): added new props showsVerticalScrollIndicator / showsHorizontalScrollIndicator (#250) 2019-02-12 14:47:24 +01:00
typings fix(types): Add new cacheEnabled prop to typescript prop type declarations (#335) 2019-02-11 22:51:44 +01:00
.all-contributorsrc chore(docs): add marconett as a contributor (#338) 2019-02-12 14:39:34 +01:00
.flowconfig Add WebView Flow types 2018-09-10 18:46:07 -06:00
.flowconfig.android Add WebView Flow types 2018-09-10 18:46:07 -06:00
.gitignore refactor(Android): New project setup + kotlin events (#121) 2018-11-19 11:25:28 +01:00
.releaserc fix(semantic-release): Use git plugin to auto commit 2018-10-18 11:37:43 +02:00
LICENSE WIP: iOS WKWebView 2018-09-08 10:42:02 -07:00
README.md chore(docs): add marconett as a contributor (#338) 2019-02-12 14:39:34 +01:00
babel.config.js fix(webviewShared.js): Support all valid URI schemes and add testing (#293) 2019-02-03 19:45:58 +01:00
index.js Added RNCWebViewManager to xcode proj 2018-08-02 23:52:31 -07:00
jest.config.js fix(webviewShared.js): Support all valid URI schemes and add testing (#293) 2019-02-03 19:45:58 +01:00
package.json chore(release): 5.2.1 [skip ci] 2019-02-14 14:19:47 +00:00
react-native-webview.podspec fix(package.json): Add license to podspec and update package.json version dynamically. (#98) 2018-10-18 11:08:49 +02:00
yarn.lock fix(webviewShared.js): Support all valid URI schemes and add testing (#293) 2019-02-03 19:45:58 +01:00

README.md

React Native WebView - a Modern, Cross-Platform WebView for React Native

star this repo PRs Welcome All Contributors Known Vulnerabilities

React Native WebView is a modern, well-supported, and cross-platform WebView for React Native. It is intended to be a replacement for the built-in WebView (which will be removed from core).

We just swapped out the React Native WebView in our app with the version from React Native Community. The swap took less than a day, required almost no code modifications, and is faster and CSS works better. Props to everyone in the community (including those at Infinite Red) that helped get that component split out.

Garrett McCullough, mobile engineer at Virta Health

Platforms Supported

  • iOS (both UIWebView and WKWebView)
  • Android

Note: React Native WebView is not currently supported by Expo unless you "eject".

Versioning

If you need the exact same WebView as the one from react-native, please use version 2.0.0. Future versions will follow semantic versioning.

Getting Started

$ yarn add react-native-webview
$ react-native link react-native-webview

Read our Getting Started Guide for more.

Usage

Import the WebView component from react-native-webview and use it like so:

import React, { Component } from "react";
import { StyleSheet, Text, View } from "react-native";
import { WebView } from "react-native-webview";

// ...
class MyWebComponent extends Component {
  render() {
    return (
      <WebView
        source={{ uri: "https://infinite.red/react-native" }}
        style={{ marginTop: 20 }}
      />
    );
  }
}

For more, read the API Reference and Guide. If you're interested in contributing, check out the Contributing Guide.

Migrate from React Native core WebView to React Native WebView

Simply install React Native WebView and then use it in place of the core WebView. Their APIs are currently identical, except that this package defaults useWebKit={true} unlike the built-in WebView.

Troubleshooting

  • If you're getting Invariant Violation: Native component for "RNCWKWebView does not exist" it likely means you forgot to run react-native link or there was some error with the linking process
  • There's a problem on some Android devices where the webview could overlap previous siblings from same parent. To fix this, wrap the WebView in a View with style overflow: hidden.

Contributing

See Contributing.md

Maintainers

Contributors

Thanks goes to these wonderful people (emoji key):

Thibault Malbranche
Thibault Malbranche

💻 🤔 👀 📖 🚧 ⚠️ 🚇 💬
Jamon Holmgren
Jamon Holmgren

💻 🤔 👀 📖 🚧 ⚠️ 💡 💬
Andrei Pfeiffer
Andrei Pfeiffer

💻 👀 🤔
Michael Diarmid
Michael Diarmid

💻 👀 🤔 🔧
Scott Mathson
Scott Mathson

💻 📖
Margaret
Margaret

💻 📖
Jordan Sexton
Jordan Sexton

💻 📖
Malcolm Scruggs
Malcolm Scruggs

💻 🔧 ⚠️
Momazo7u7
Momazo7u7

📖
Marco
Marco

📖

This project follows the all-contributors specification. Contributions of any kind welcome!

License

MIT