Cho*_*Fan 4 javascript react-native
是否可以在WebView组件内创建一个函数,触发React Native函数?
小智 5
有可能,但是我不确定这是否是唯一的方法。
基本上,您可以设置一个onNavigationStateChange事件处理程序,并将函数调用信息嵌入到导航URL中,这是该概念的示例。
在React Native上下文中
render() {
return <WebView onNavigationStateChange={this._onURLChanged.bind(this)} />
}
_onURLChanged(e) {
// allow normal the natvigation
if(!e.url.startsWith('native://'))
return true
var payload = JSON.parse(e.url.replace('native://', ''))
switch(e.functionName) {
case 'toast' :
native_toast(e.data)
break
case 'camera' :
native_take_picture(e.data)
break
}
// return false to prevent webview navitate to the location of e.url
return false
}
Run Code Online (Sandbox Code Playgroud)
要调用本机方法,只需使用此方法即可触发Webview的导航事件并将函数调用信息嵌入URL。
window.location = 'native://' + JSON.stringify({
functionName : 'toast', data : 'show toast text'
})
Run Code Online (Sandbox Code Playgroud)
使用onMessage事件监听器<WebView/>
<WebView onMessage={onMessage} ... />
Run Code Online (Sandbox Code Playgroud)
/** on message from webView -- window.ReactNativeWebView?.postMessage(data) */
const onMessage = event => {
const {
nativeEvent: {data},
} = event;
if (data === 'goBack') {
navigation.goBack();
} else if (data?.startsWith('navigate')) {
// navigate:::routeName:::stringifiedParams
try {
const [, routeName, params] = data.split(':::');
params = params ? JSON.parse(params) : {};
navigation.navigate(routeName, params);
} catch (err) {
console.log(err);
}
}
};
Run Code Online (Sandbox Code Playgroud)
在 HTML 中使用它来发布消息事件
window.ReactNativeWebView?.postMessage("data")
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3650 次 |
| 最近记录: |