首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React Native - Webview调用React Native函数

React Native - Webview调用React Native函数
EN

Stack Overflow用户
提问于 2016-08-19 17:00:52
回答 5查看 7.8K关注 0票数 8

有没有可能在WebView组件中创建一个函数,触发React Native函数?

EN

回答 5

Stack Overflow用户

发布于 2016-08-19 17:32:46

这是可能的,但我不确定这是否是唯一的方法。

基本上,您可以设置一个onNavigationStateChange事件处理程序,并在导航url中嵌入函数调用信息,这是一个概念示例。

在React Native上下文中

代码语言:javascript
复制
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

}

要调用原生方法,只需触发webview的导航事件并将函数调用信息嵌入到URL中即可。

代码语言:javascript
复制
window.location = 'native://' + JSON.stringify({ 
    functionName : 'toast', data : 'show toast text' 
})
票数 7
EN

Stack Overflow用户

发布于 2017-05-12 05:15:54

您可以在加载时将javascript函数注入webview,然后使用onMessage从您注入更多信息的函数中获得响应IN Here

票数 2
EN

Stack Overflow用户

发布于 2021-07-22 22:00:57

<WebView/>上使用onMessage eventListner

代码语言:javascript
复制
<WevView onMessage={onMessage} ... />
代码语言:javascript
复制
/** 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);
      }
    }
  };

在HTML中使用它来发布消息事件

代码语言:javascript
复制
window.ReactNativeWebView?.postMessage("data")
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39035026

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档