HarmonyOS H5调用拨打电话的方法,导致ArkWeb白屏

H5页面上有展示号码的按钮,点击按钮,其他系统都可以弹出原生系统的拨打电话的界面,但是用Arkweb去加载这个H5页面,点击电话号码按钮的时候,不能拉起HarmonyOS系统拨打电话的界面,而且还会导致ArkWeb出现白屏的现象

H5侧调用的方式是:window.location.href = tel:XXXXX

请问,这个兼容性的问题,怎么解决,必须需要HarmonyOS原生编码实现,唤起拨打电话的界面么?

HarmonyOS
2天前
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
shlp

目前H5不能直接拉起应用,需要应用侧适配,可以不修改H5代码,在应用侧拦截并拉起通话

应用侧demo:

// xxx.ets
import { webview } from '@kit.ArkWeb';
import { call } from '@kit.TelephonyKit';

@Entry
@Component
struct WebComponent {
  webviewController: webview.WebviewController = new webview.WebviewController();

  build() {
    Column() {
      Web({ src: $rawfile('xxx.html'), controller: this.webviewController })
        .onLoadIntercept((event) => {
          if (event) {
            let url: string = event.data.getRequestUrl();
            // 判断链接是否为拨号链接
            if (url.indexOf('tel:') === 0) {
              // 跳转拨号界面
              call.makeCall(url.substring(4), (err) => {
                if (!err) {
                  console.info('make call succeeded.');
                } else {
                  console.info('make call fail, err is:' + JSON.stringify(err));
                }
              });
              return true;
            }
          }
          return false;
        })
    }
  }
}

在没有做拦截之前,window.location.href会打开新窗口,但是新窗口的tel:XXXX没有内容,就会白屏,再拦截window.location.href后,将执行拦截后的拉起通话动作,不再执行打开新窗口,就不会出现白屏,onLoadIntercept:当Web组件加载url之前触发该回调,用于判断是否阻止此次访问。

分享
微博
QQ
微信
回复
2天前
相关问题
HarmonyOS 如何调用拨打电话界面
240浏览 • 1回复 待解决
HarmonyOS 拨打电话功能
16浏览 • 1回复 待解决
HarmonyOS 拨打电话系统能力
738浏览 • 1回复 待解决
HarmonyOS APP能否直接进行拨打电话
15浏览 • 1回复 待解决
HarmonyOS 如何直接调起拨打电话
213浏览 • 1回复 待解决
申请拨打电话权限无效
6249浏览 • 1回复 待解决
HarmonyOS有没有拨打电话相关资料
577浏览 • 1回复 待解决
HarmonyOS Web组件加载H5白屏
183浏览 • 1回复 待解决
HarmonyOS 判断是否有拨打电话权限
280浏览 • 1回复 待解决
HarmonyOSh5前端侧调用应用侧方法
171浏览 • 2回复 待解决
HarmonyOS app调用打电话功能报错
402浏览 • 1回复 待解决
HarmonyOS ArkTS与H5交互方法
256浏览 • 1回复 待解决
HarmonyOS H5调用原生扫码功能
237浏览 • 1回复 待解决
HarmonyOS H5调用APP图库选择图片
175浏览 • 1回复 待解决
HarmonyOS h5调用系统相机进行拍照
200浏览 • 1回复 待解决