Skip to content

繼承自ReactNative的WebView, 擴展 自動獲取焦點、彈出鍵盤 屬性,支持在WebView的基礎上自定義

Notifications You must be signed in to change notification settings

TryImpossible/react-native-enhance-webview

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

react-native-enhance-webview

Getting started

$ npm install react-native-enhance-webview --save

Mostly automatic installation

$ react-native link react-native-enhance-webview

Manual installation

iOS

  1. In XCode, in the project navigator, right click LibrariesAdd Files to [your project's name]
  2. Go to node_modulesreact-native-enhance-webview and add RNEnhanceWebview.xcodeproj
  3. In XCode, in the project navigator, select your project. Add libRNEnhanceWebview.a to your project's Build PhasesLink Binary With Libraries
  4. Run your project (Cmd+R)

Android

  1. Open up android/app/src/main/java/[...]/MainActivity.java
  • Add import com.enhancewebview.RNEnhanceWebviewPackage; to the imports at the top of the file
  • Add new RNEnhanceWebviewPackage() to the list returned by the getPackages() method
  1. Append the following lines to android/settings.gradle:
    include ':react-native-enhance-webview'
    project(':react-native-enhance-webview').projectDir = new File(rootProject.projectDir, 	'../node_modules/react-native-enhance-webview/android')
    
  2. Insert the following lines inside the dependencies block in android/app/build.gradle:
      compile project(':react-native-enhance-webview')
    

Usage

import RNEnhanceWebview from 'react-native-enhance-webview';

render() {
	 const { width, height } = Dimensions.get("window");
    const pageSource = { uri: 'http://192.168.0.33:8081/html/test.html' };
    // const pageSource = { uri: 'https://www.baidu.com/' };
    return (
      <View style={{ width, height }}>
        <RNEnhanceWebview
            ref={ref => this.webView = ref}
            style={{ flex: 1, width }}
            source={pageSource}
            keyboardDisplayRequiresUserAction={false} //ios自動獲取焦點
	         autoFocus={true} //android自動獲取焦點
            // injectedJavaScript={'alert(123)'}
            automaticallyAdjustContentInsets={false}
            allowFileAccessFromFileURLs={true}
            scalesPageToFit={false}
            mixedContentMode={'always'}
            javaScriptEnabled={true}
            startInLoadingState={true}
            dataDetectorTypes='none'
            onMessage={event => {
              // let ret = JSON.parse(event.nativeEvent.data);
              // console.log(event.nativeEvent.data);
            }}
            onLoad={() => {

            }} />
        </View>
    ) 
}

Description

  • RNEnhanceWebview繼承ReactNative提供的組件WebView,支持WebView 的所有props 和 static method。 WebView文檔
  • 增加autoFocus,用於Android自動獲取焦點並彈出鍵盤,默認false;
  • 增加keyboardDisplayRequiresUserAction , 用於ios自動獲取焦點並彈出鍵盤,默認true;

ReactNative開發App時,需要實現一個的功能,即在H5中讓input標籤自動獲取焦點並彈出鍵盤。但是,ReactNative提供的WebvView組件並沒有提供這個屬性或方法。被逼無奈,只好自己去想辦法增實現。為了儘量兼容ReactNative提供的WebvViewNative端採用繼承的方式實現WebView,並添加自動獲取焦點和彈出鍵盤的Props; ReactNative覆寫WebView.android.jsWebView.ios.js文件,添加autoFocus keyboardDisplayRequiresUserAction props; 目前這種解決方式比較靠譜,既支持了ReactNativeWebView,又方便自定義WebView;

GIF

ios效果圖 android效果圖

About

繼承自ReactNative的WebView, 擴展 自動獲取焦點、彈出鍵盤 屬性,支持在WebView的基礎上自定義

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published