模板版本:v0.2.2
[!TIP] Github 地址
请到三方库的 Releases 发布地址查看配套的版本信息:@react-native-oh-tpl/react-native-webview Releases 。对于未发布到npm的旧版本,请参考安装指南安装tgz包。
进入到工程目录并输入以下命令:
npm install @react-native-oh-tpl/react-native-webview
yarn add @react-native-oh-tpl/react-native-webview
下面的代码展示了这个库的基本使用场景:
[!WARNING] 使用时 import 的库名不变。
import { WebView } from "react-native-webview";
export default function WebViewDemo() {
return (
<WebView source={{ uri: "https://reactnative.dev/" }} />
);
}
本库已经适配了 Codegen
,在使用前需要主动执行生成三方库桥接代码,详细请参考 Codegen 使用文档。
目前 HarmonyOS 暂不支持 AutoLink,所以 Link 步骤需要手动配置。
首先需要使用 DevEco Studio 打开项目里的 HarmonyOS 工程 harmony
{
...
"overrides": {
"@rnoh/react-native-openharmony" : "./react_native_openharmony"
}
}
目前有两种方法:
- 通过 har 包引入(在 IDE 完善相关功能后该方法会被遗弃,目前首选此方法);
- 直接链接源码。
方法一:通过 har 包引入
[!TIP] har 包位于三方库安装路径的
harmony
文件夹下。
打开 entry/oh-package.json5
,添加以下依赖
"dependencies": {
"@rnoh/react-native-openharmony": "file:../react_native_openharmony",
"@react-native-oh-tpl/react-native-webview": "file:../../node_modules/@react-native-oh-tpl/react-native-webview/harmony/rn_webview.har"
}
点击右上角的 sync
按钮
或者在终端执行:
cd entry
ohpm install
方法二:直接链接源码
[!TIP] 如需使用直接链接源码,请参考直接链接源码说明
找到 function buildCustomComponent(),一般位于 entry/src/main/ets/pages/index.ets
或 entry/src/main/ets/rn/LoadBundle.ets
,添加:
+ import { WebView, WEB_VIEW } from "@react-native-oh-tpl/react-native-webview"
@Builder
function buildCustomComponent(ctx: ComponentBuilderContext) {
+ if (ctx.componentName === WEB_VIEW) {
+ WebView({
+ ctx: ctx.rnComponentContext,
+ tag: ctx.tag
+ })
+ }
...
}
...
[!TIP] 本库使用了混合方案,需要添加组件名。
在entry/src/main/ets/pages/index.ets
或 entry/src/main/ets/rn/LoadBundle.ets
找到常量 arkTsComponentNames
在其数组里添加组件名
const arkTsComponentNames: Array<string> = [
SampleView.NAME,
GeneratedSampleView.NAME,
PropsDisplayer.NAME,
+ WEB_VIEW
];
打开 entry/src/main/ets/RNPackagesFactory.ts
,添加:
import type {RNPackageContext, RNPackage} from 'rnoh/ts';
import {SamplePackage} from 'rnoh-sample-package/ts';
+ import { WebViewPackage } from '@react-native-oh-tpl/react-native-webview/ts';
export function createRNPackages(ctx: RNPackageContext): RNPackage[] {
return [
new SamplePackage(ctx),
+ new WebViewPackage(ctx)
];
}
点击右上角的 sync
按钮
或者在终端执行:
cd entry
ohpm install
然后编译、运行即可。
要使用此库,需要使用正确的 React-Native 和 RNOH 版本。另外,还需要使用配套的 DevEco Studio 和 手机 ROM。
请到三方库相应的 Releases 发布地址查看 Release 配套的版本信息: @react-native-oh-tpl/react-native-webview Releases
[!TIP] "Platform"列表示该属性在原三方库上支持的平台。
[!TIP] "HarmonyOS Support"列为 yes 表示 HarmonyOS 平台支持该属性;no 则表示不支持;partially 表示部分支持。使用方法跨平台一致,效果对标 iOS 或 Android 的效果。
详情请查看webview 官方文档
Name | Description | Type | Required | Platform | HarmonyOS Support |
---|---|---|---|---|---|
source |
Loads static HTML or a URI (with optional headers) in the WebView | object | yes | All | partially (Only of: Load uri : uri headers Static HTML : html baseUrl) |
injectedJavaScript? |
Set this to provide JavaScript that will be injected into the web page after the document finishes loading | string | No | All | yes |
originWhitelist? |
List of origin strings to allow being navigated to. | string[] | No | iOS,Android,macOS | yes |
scalesPageToFit? |
Boolean that controls whether the web content is scaled to fit the view and enables the user to change the scale. | boolean | No | Android | yes |
startInLoadingState? |
Boolean value that forces the WebView to show the loading view on the first load. | boolean | No | iOS,Android,macOS | yes |
style? |
A style object that allow you to customize the WebView style. | Style | No | ALL | yes |
domStorageEnabled? |
Boolean value to control whether DOM Storage is enabled. Used only in Android and harmony. | boolean | No | Android | yes |
javaScriptEnabled? |
Boolean value to enable JavaScript in the WebView. | boolean | No | All | yes |
showsHorizontalScrollIndicator? |
Boolean value that determines whether a horizontal scroll indicator is shown in the WebView. | boolean | No | iOS,Android,macOS | yes |
showsVerticalScrollIndicator |
Boolean value that determines whether a vertical scroll indicator is shown in the WebView. | boolean | No | iOS,Android,macOS | yes |
ignoreSilentHardwareSwitch |
Boolean value that When set to true the hardware silent switch is ignored. | boolean | No | iOS | yes |
cacheEnabled? |
Sets whether WebView should use browser caching. | boolean | No | iOS,Android,macOS | yes |
cacheMode? |
Overrides the way the cache is used. | string | No | Android | yes |
textZoom? |
If the user has set a custom font size in the Android and harmony system, an undesirable scale of the site interface in WebView occurs. | number | No | Android | yes |
incognito? |
Does not store any data within the lifetime of the WebView. | boolean | NO | All | yes |
mediaPlaybackRequiresUserAction? |
Boolean that determines whether HTML5 audio and video requires the user to tap them before they start playing. The default value is true . (Android API minimum version 17). |
boolean | NO | iOS,Android,macOS | yes |
geolocationEnabled? |
Set whether Geolocation is enabled in the WebView . The default value is false . Used only in Android. |
boolean | NO | Android | yes |
fraudulentWebsiteWarningEnabled? |
A Boolean value that indicates whether the web view shows warnings for suspected fraudulent content, such as malware or phishing attempts. The default value is true . (iOS 13+) |
boolean | NO | iOS | yes |
thirdPartyCookiesEnabled? |
Boolean value to enable third party cookies in the WebView . Used on Android Lollipop and above only as third party cookies are enabled by default on Android Kitkat and below and on iOS. The default value is true . For more on cookies, |
boolean | NO | Android | yes |
userAgent? |
Sets the user-agent for the WebView . |
string | NO | iOS,Android,macOS | yes |
minimumFontSize? |
Android enforces a minimum font size based on this value. A non-negative integer between 1 and 72. Any number outside the specified range will be pinned. Default value is 8. If you are using smaller font sizes and are having trouble fitting the whole window onto one screen, try setting this to a smaller value. | number | No | Android | yes |
forceDarkOn? |
Configuring Dark Theme | boolean | No | Android | yes |
injectedJavaScriptBeforeContentLoaded? |
Set this to provide JavaScript that will be injected into the web page after the document element is created, but before other subresources finish loading. | string | No | iOS,Android,macOS | yes |
automaticallyAdjustContentInsets? |
Controls whether to adjust the content inset for web views that are placed behind a navigation bar, tab bar, or toolbar. The default value is true |
boolean | No | iOS | No |
automaticallyAdjustsScrollIndicatorInsets? |
Controls whether to adjust the scroll indicator inset for web views that are placed behind a navigation bar, tab bar, or toolbar. The default value false . (iOS 13+) |
boolean | No | iOS | No |
injectedJavaScriptBeforeContentLoadedForMainFrameOnly? |
If true (default; mandatory for Android), loads the injectedJavaScriptBeforeContentLoaded only into the main frame. |
boolean | No | iOS | No |
nativeConfig? |
Override the native component used to render the WebView. Enables a custom native WebView which uses the same JavaScript as the original WebView. | object | No | iOS, Android, macOS | No |
decelerationRate? |
A floating-point number that determines how quickly the scroll view decelerates after the user lifts their finger. You may also use the string shortcuts "normal" and "fast" which match the underlying iOS |
number | No | iOS | No |
javaScriptCanOpenWindowsAutomatically? |
A Boolean value indicating whether JavaScript can open windows without user interaction. The default value is false . |
boolean | No | iOS, Android, macOS | No |
AndroidLayerType? |
Specifies the layer type. | string | No | Android | No |
mixedContentMode? |
Specifies the mixed content mode. i.e WebView will allow a secure origin to load content from any other origin. | string | No | Android | No |
allowsFullscreenVideo? |
Boolean that determines whether videos are allowed to be played in fullscreen. The default value is false. | boolean | NO | Android | NO |
allowsInlineMediaPlayback? |
Boolean that determines whether HTML5 videos play inline or use the native full-screen controller. The default value is false . |
boolean | NO | iOS | NO |
allowsAirPlayForMediaPlayback? |
A Boolean value indicating whether AirPlay is allowed. The default value is false . |
boolean | NO | iOS and macOS | NO |
contentInset? |
The amount by which the web view content is inset from the edges of the scroll view. Defaults to {top: 0, left: 0, bottom: 0, right: 0}. | object | NO | iOS | NO |
contentInsetAdjustmentBehavior? |
This property specifies how the safe area insets are used to modify the content area of the scroll view. The default value of this property is "never". Available on iOS 11 and later. Defaults to never . |
string | NO | iOS | NO |
contentMode? |
Controls the type of content to load. Available on iOS 13 and later. Defaults to recommended , which loads mobile content on iPhone & iPad Mini but desktop content on larger iPads. |
string | No | iOS | No |
dataDetectorTypes? |
Determines the types of data converted to clickable URLs in the web view's content. By default only phone numbers are detected. | string, or array | NO | ios | NO |
setBuiltInZoomControls? |
Sets whether the WebView should use its built-in zoom mechanisms. The default value is true . Setting this to false will prevent the use of a pinch gesture to control zooming. |
boolean | NO | Android | NO |
setDisplayZoomControls? |
Sets whether the WebView should display on-screen zoom controls when using the built-in zoom mechanisms (see setBuiltInZoomControls ). The default value is false . |
boolean | NO | Android | NO |
directionalLockEnabled? |
A Boolean value that determines whether scrolling is disabled in a particular direction. The default value is true . |
boolean | NO | iOS | NO |
allowFileAccessFromFileURLs? |
Boolean that sets whether JavaScript running in the context of a file scheme URL should be allowed to access content from other file scheme URLs. The default value is false . |
boolean | NO | iOS, Android, macOS | NO |
allowUniversalAccessFromFileURLs? |
boolean | NO | No | iOS, Android, macOS | No |
allowingReadAccessToURL |
A String value that indicates which URLs the WebView's file can then reference in scripts, AJAX requests, and CSS imports. This is only used in for WebViews that are loaded with a source.uri set to a 'file://' URL. If not provided, the default is to only allow read access to the URL provided in source.uri itself. |
string | NO | iOS and macOS | NO |
keyboardDisplayRequiresUserAction? |
If false , web content can programmatically display the keyboard. The default value is true . |
boolean | NO | iOS and macOS | NO |
hideKeyboardAccessoryView? |
If true , this will hide the keyboard accessory view (< > and Done). |
boolean | NO | iOS | NO |
allowsBackForwardNavigationGestures? |
If true , this will be able horizontal swipe gestures. The default value is false . |
boolean | NO | iOS | No |
allowFileAccess? |
If true , this will allow access to the file system via file:// URI's. The default value is false . |
boolean | NO | Android | NO |
saveFormDataDisabled? |
Sets whether the WebView should disable saving form data. The default value is false . This function does not have any effect from Android API level 26 onwards as there is an Autofill feature which stores form data. |
boolean | NO | Android | NO |
pagingEnabled? |
If the value of this property is true , the scroll view stops on multiples of the scroll view’s bounds when the user scrolls. The default value is false . |
boolean | NO | iOS | NO |
allowsLinkPreview? |
A Boolean value that determines whether pressing on a link displays a preview of the destination for the link. In iOS this property is available on devices that support 3D Touch. In iOS 10 and later, the default value is true ; before that, the default value is false |
boolean | NO | iOS and macOS | NO |
sharedCookiesEnabled? |
Set true if shared cookies from [NSHTTPCookieStorage sharedHTTPCookieStorage] should be used for every load request in the WebView. The default value is false . For more on cookies, read the Guide |
boolean | NO | iOS and macOS | NO |
limitsNavigationsToAppBoundDomains? |
If true indicates to WebKit that a WKWebView will only navigate to app-bound domains. Only applicable for iOS 14 or greater. |
boolean | NO | iOS | No |
textInteractionEnabled? |
If false indicates to WebKit that a WKWebView will not interact with text, thus not showing a text selection loop. Only applicable for iOS 14.5 or greater. | boolean | NO | iOS | NO |
suppressMenuItems? |
Allows to suppress menu item from the default context menu. | array of strings | NO | iOS | NO |
mediaCapturePermissionGrantType? |
This property specifies how to handle media capture permission requests. Defaults to prompt , resulting in the user being prompted repeatedly. Available on iOS 15 and later. |
string | NO | iOS | No |
autoManageStatusBarEnabled? |
If set to true , the status bar will be automatically hidden/shown by WebView, specifically when full screen video is being watched. If false , WebView will not manage the status bar at all. The default value is true . |
boolean | NO | iOS | NO |
basicAuthCredential ? |
object that specifies the credentials of a user to be used for basic authentication. | object | NO | iOS, Android | NO |
useWebView2? |
Use WinUI WebView2 control instead of WebView control as the native webview. The WebView2 control is a WinUI control that renders web content using the Microsoft Edge (Chromium) rendering engine. Option can be toggled at runtime and supports Fast Refresh. | boolean | NO | Windows | NO |
applicationNameForUserAgent? |
Append to the existing user-agent. Setting userAgent will override this. |
string | No | All | yes |
thirdPartyCookiesEnabled? |
Boolean value to enable third party cookies in the WebView . Used on Android Lollipop and above only as third party cookies are enabled by default on Android Kitkat and below and on iOS. The default value is true . |
boolean | No | All | yes |
[!TIP] "Platform"列表示该属性在原三方库上支持的平台。
[!TIP] "HarmonyOS Support"列为 yes 表示 HarmonyOS 平台支持该属性;no 则表示不支持;partially 表示部分支持。使用方法跨平台一致,效果对标 iOS 或 Android 的效果。
Name | Description | Type | Required | Platform | HarmonyOS Support |
---|---|---|---|---|---|
onScroll?: (event) => void |
Function that is invoked when the scroll event is fired in the WebView . |
function | No | iOS and macOS | yes |
onHttpError?: (event) => void |
Function that is invoked when the WebView receives an http error. |
function | No | yes | yes |
onLoadStart?: (event) => void |
Function that is invoked when the WebView starts loading. |
function | No | All | yes |
onLoad?: (event) => void |
Function that is invoked when the WebView has finished loading. |
function | No | All | yes |
onOpenWindow? |
Function that is invoked when the WebView should open a new window. |
function | No | iOS, Android, macOS | No |
injectJavaScript?: (script: string) => void |
Executes the JavaScript string. | function | No | iOS,Android,macOS | yes |
onLoadEnd?: (event) => void |
Function that is invoked when the WebView load succeeds or fails used. | function | No | All | yes |
onLoadProgress?: (event) => void |
Function that is invoked when the WebView is loading. | function | No | All | yes |
onMessage?: (event) => void |
Function that is invoked when the webview calls window.ReactNativeWebView.postMessage. | function | No | iOS,Android,macOS | yes |
onShouldStartLoadWithRequest?: (event) => void |
Function that allows custom handling of any web view requests. | function | No | iOS,Android,macOS | yes |
onContentProcessDidTerminate: (event) => void |
Function that is invoked when the WebView content process is terminated. |
function | No | iOS and macOS WKWebView | No |
renderLoading? |
Function that returns a loading indicator. The startInLoadingState prop must be set to true in order to use this prop. |
function | No | iOS, Android, macOS | No |
onCustomMenuSelection? |
Function called when a custom menu item is selected. It receives a Native event, which includes three custom keys: label , key and selectedText . |
function | NO | iOS, Android | No |
[!TIP] "Platform"列表示该属性在原三方库上支持的平台。
[!TIP] "HarmonyOS Support"列为 yes 表示 HarmonyOS 平台支持该属性;no 则表示不支持;partially 表示部分支持。使用方法跨平台一致,效果对标 iOS 或 Android 的效果。
Name | Description | Type | Required | Platform | HarmonyOS Support |
---|---|---|---|---|---|
goForward() |
Go forward one page in the web view's history. | function | No | All | yes |
goBack() |
Go back one page in the web view's history. | function | No | All | yes |
reload() |
Reloads the current page. | function | No | All | yes |
stopLoading() |
Stop loading the current page. | function | No | All | yes |
injectJavaScript(script: string) |
This function corresponds to the completion handler in Apple's recovery user interface ForPictureInPictureStop. IMPORTANT: This function must be called after calling onRestoreUserInterfaceForPictureInPictureStop. | function | No | All | yes |
requestFocus() |
Request the webView to ask for focus. (People working on TV apps might want having a look at this!) | function | No | All | yes |
postMessage(data:string) |
Post a message to WebView, handled by onMessage . |
function | No | All | yes |
clearFormData() |
Removes the autocomplete popup from the currently focused form field, if present. | function | No | Android | No |
clearCache(status:boolean) |
Clears the resource cache. Note that the cache is per-application, so this will clear the cache for all WebViews used. | function | No | All | yes |
clearHistory() |
Tells this WebView to clear its internal back/forward list. | function | No | Android | yes |
本项目基于 The MIT License (MIT) ,请自由地享受和参与开源。