Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/beefe/react-native-webview
Deprecated
https://github.com/beefe/react-native-webview
Last synced: about 2 months ago
JSON representation
Deprecated
- Host: GitHub
- URL: https://github.com/beefe/react-native-webview
- Owner: beefe
- Created: 2015-12-08T07:25:41.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2015-12-22T06:34:47.000Z (about 9 years ago)
- Last Synced: 2024-08-16T18:55:39.598Z (5 months ago)
- Language: Java
- Homepage:
- Size: 405 KB
- Stars: 4
- Watchers: 7
- Forks: 2
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-react-native - react-native-webview ★3 - android webview for react-native (Components / Web)
- awesome-react-native - react-native-webview ★3 - android webview for react-native (Components / Web)
- awesome-react-native - react-native-webview ★3 - android webview for react-native (Components / Web)
- awesome-react-native-ui - react-native-webview ★1 - android webview for react-native (Components / Web)
- awesome-react-native - react-native-webview ★3 - android webview for react-native (Components / Web)
README
# The [react-native version 0.17.1](https://github.com/facebook/react-native/blob/master/ReactAndroid/src/main/java/com/facebook/react/views/webview/ReactWebViewManager.java) has been achieved This component , this project is no longer being maintained.
# react-native-webview
android webview for react-native## 已经实现的属性和方法
### Props
* automaticallyAdjustContentInsets
```javascript
bool
```
* html
```javascript
string
```
* injectedJavaScript
```javascript
string
```
* onNavigationStateChange
```javascript
function
```
* url
```javascript
string
```
* javaScriptEnabledAndroid
```javascript
bool
```
### method
* goBack
* goForward
* reload## Installation and How to use
#### Step 1 - NPM Install
```shell
npm install --save react-native-webview
```
#### Step 2 - Update Gradle Settings```gradle
// file: android/settings.gradle
...include ':reactwebview', ':app'
project(':reactwebview').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-webview')
// if there are more library
// include ':app' , ':libraryone' , ':librarytwo' , 'more...'
// project(':libraryonename').projectDir = new File(rootProject.projectDir, '../node_modules/libraryonemodule')
// project(':librarytwoname').projectDir = new File(rootProject.projectDir, '../node_modules/librarytwomodule')
// more..
```#### Step 3 - Update app Gradle Build
```gradle
// file: android/app/build.gradle
...dependencies {
...
compile project(':reactwebview')
}
```#### Step 4 - Register React Package
```java
...
import com.heng.wheel.WheelPackage;public class MainActivity extends Activity implements DefaultHardwareBackBtnHandler {
private ReactInstanceManager mReactInstanceManager;
private ReactRootView mReactRootView;@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mReactRootView = new ReactRootView(this);
mReactInstanceManager = ReactInstanceManager.builder()
.setApplication(getApplication())
.setBundleAssetName("index.android.bundle")
.setJSMainModuleName("index.android")
.addPackage(new MainReactPackage())
.addPackage(new WebViewPackage()) // register webview package
.setUseDeveloperSupport(BuildConfig.DEBUG)
.setInitialLifecycleState(LifecycleState.RESUMED)
.build();
...
}
...```
#### Step 5 - Require and use in Javascript
```js
// file: index.android.jsvar React = require('react-native');
var {
AppRegistry,
StyleSheet,
} = React;var WebView = require('react-native-webview');
var WebViewTest = React.createClass({
goBack: function() {
this.refs.webview.goBack();
},
goForward: function() {
this.refs.webview.goForward();
},
reload: function() {
this.refs.webview.reload();
},
_onNavigationStateChange: function(event) {
//event.canGoBack
//event.canGoForward
//event.url
//event.title
//event.loading
},
render: function() {
var reqUrl = "https://github.com/";
return (
);
}
});var styles = StyleSheet.create({
webview: {
flex: 1,
},
});...
```## Notes
- Only in the following versions tested , other versions do not guarantee success
```gradle
// file: react-native-wheel/build.gradleandroid {
compileSdkVersion 23 //@
buildToolsVersion "23.0.1" //@defaultConfig {
minSdkVersion 16
targetSdkVersion 22 //@
}
}dependencies {
compile 'com.facebook.react:react-native:0.16.1' //@
}
```## Remark
在模拟器运行会提示以下错误:
Webpage not availableThe webpage at "xxx" could not be loaded because:
net::ERR_NAME_NOT_RESOLVED
暂未寻找解决方案,目前建议[打包导出](http://facebook.github.io/react-native/docs/signed-apk-android.html#content)后在真机运行
## Run Renderings