HarmonyOS 鸿蒙Next WebView 调用原生方法问题

发布于 1周前 作者 sinazl 来自 鸿蒙OS

HarmonyOS 鸿蒙Next WebView 调用原生方法问题

同样的一个dialog,在普通的页面中能够显示出来,但是webview调用的action中弹dialog弹不出来 是为啥

@CustomDialog
export struct PermissionConfirmDialog {
build(){

  }
}


关于HarmonyOS 鸿蒙Next WebView 调用原生方法问题的问题,您也可以访问:https://www.itying.com/category-93-b0.html 联系官网客服。


更多关于HarmonyOS 鸿蒙Next WebView 调用原生方法问题的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

11 回复

找HarmonyOS工作还需要会Flutter技术的哦,有需要Flutter教程的可以学学大地老师的教程,很不错,B站免费学的哦:https://www.bilibili.com/video/BV1S4411E7LY/?p=17

更多关于HarmonyOS 鸿蒙Next WebView 调用原生方法问题的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


import Logger from '../common/utils/Logger';
import { CommonConstants } from '../common/constants/CommonConstants';
import { ArkTSFunModel, BridgeProxy } from '../model/ProductModel';
import { LogoutConfirmDialog } from '../common/LogoutConfirmDialog';
import JSBridge from '../common/constants/JSBridge';

博主,这几个文件能提供一下吗?

希望HarmonyOS能继续加强与其他应用的兼容性,让用户体验更加完美。

我也遇到了 请问解决了吗 我用eventHub发消息出来 aboutToAppear这边接收 可以弹出来

HarmonyOS的分布式文件系统让我在多设备间共享文件变得更加方便。

就是 h5 调用我的原生的一个action(方法),action里面调用 一个例如showShareDialog 这种形式是不行的是么?

demo发一下我看看

希望HarmonyOS能继续加强在安全性方面的研发,保护用户的隐私和数据安全。

import { BusinessError } from ‘@kit.BasicServicesKit’; import { router, promptAction } from ‘@kit.ArkUI’; import { webview }from ‘@kit.ArkWeb’; import { window } from ‘@kit.ArkUI’; import Logger from ‘…/common/utils/Logger’; import { CommonConstants } from ‘…/common/constants/CommonConstants’; import { ArkTSFunModel, BridgeProxy } from ‘…/model/ProductModel’; import { LogoutConfirmDialog } from ‘…/common/LogoutConfirmDialog’; import JSBridge from ‘…/common/constants/JSBridge’;

const TAG = ‘[IndexPage]’;

@Entry @Component struct IndexPage { @State @Watch(‘updateStatus’) webCanBack: boolean = false; @State webCanForward: boolean = false; @State controller: webview.WebviewController = new webview.WebviewController(); @State statusBarHeight: number = 0; @State sliderBarHeight: number = 0; arkTSObj: ArkTSFunModel = { jumpOrderConfirm: (detailStr: string) => this.jumpOrderConfirm(detailStr) };

private jsBridge: JSBridge = new JSBridge(this.controller);

bridgeProxy:BridgeProxy ={ object:this.arkTSObj, name: ‘arkTSFunObj’, methodList: [‘jumpOrderConfirm’], controller: this.controller }

aboutToAppear() { webview.WebviewController.setWebDebuggingAccess(true); window.getLastWindow(getContext(this), (err: BusinessError, windowClass: window.Window) => { if (err.code) { Logger.error(TAG, 'Failed to obtain the main window. Cause: ’ + JSON.stringify(err)); return; } Logger.info(TAG, 'Succeeded in obtaining the main window. Data: ’ + JSON.stringify(windowClass));

  // Realize the immersive effect.
  try {
    let type = window.AvoidAreaType.TYPE_SYSTEM;
    // Get status bar height.
    let area: window.AvoidArea = windowClass.getWindowAvoidArea(type);
    let statusBarHeight = px2vp(area.topRect.height);
    let sliderBarHeight = px2vp(area.bottomRect.height);
    this.statusBarHeight = statusBarHeight;
    this.sliderBarHeight = sliderBarHeight;
    if (statusBarHeight > 0) {
      windowClass.setWindowLayoutFullScreen(true);
    }
  } catch (exception) {
    Logger.error(TAG, 'Failed to set the system bar properties. Cause: ' + JSON.stringify(exception));
  }
});

}

onPageShow() { this.updateStatusBar(this.webCanBack); }

onPageHide() { this.updateStatusBar(false); }

updateStatus() { this.updateStatusBar(this.webCanBack); }

onBackPress() { if (this.webCanBack) { this.controller.backward(); return true; } return false; }

updateStatusBar(isDarkMode?: boolean): void {

}

dialogController?: CustomDialogController

private logout(){ if(!this.dialogController){ this.dialogController = new CustomDialogController({ builder: LogoutConfirmDialog({ cancel: ()=>{ }, controller:this.dialogController }), offset: {dx:0,dy:0}, autoCancel:true, customStyle:true, isModal:true, alignment: DialogAlignment.Center, // 可设置dialog的对齐方式,设定显示在底部或中间等,默认为底部显示 }) } this.dialogController?.open() }

jumpOrderConfirm(detailStr: string): string { this.logout() return “你点击了跳转111” }

build() { Column() { Web({ src: $rawfile(‘product_list.html’), controller: this.controller }) .margin({ top: AppStorage.get(‘statusBarHeight’) }) .layoutWeight(1) .javaScriptProxy(this.bridgeProxy) .onConfirm(() => { promptAction.showToast({ message: $r(‘app.string.toast_msg’), duration: CommonConstants.TOAST_DURATION }); return false; }) .onPageEnd(() => { this.webCanBack = this.controller.accessBackward(); this.webCanForward = this.controller.accessForward(); })

  Row() {
    Button() {
      Image(this.webCanBack ? $r('app.media.ic_back_on') : $r('app.media.ic_back_off'))
        .width($r('app.float.img_size'))
        .aspectRatio(1)
    }
    .width($r('app.float.btn_size'))
    .backgroundColor($r('app.color.common_bg'))
    .aspectRatio(1)
    .enabled(this.webCanBack)
    .onClick(() => {
      this.controller.backward();
    })

    Button() {
      Image(this.webCanForward ? $r('app.media.ic_next_on') : $r('app.media.ic_next_off'))
        .width($r('app.float.img_size'))
        .aspectRatio(1)
    }
    .width($r('app.float.btn_size'))
    .backgroundColor($r('app.color.common_bg'))
    .aspectRatio(1)
    .enabled(this.webCanForward)
    .onClick(() => {
      this.controller.forward();
    })

    Button() {
      Image($r('app.media.ic_home'))
        .width($r('app.float.img_size'))
        .aspectRatio(1)
    }
    .width($r('app.float.btn_size'))
    .backgroundColor($r('app.color.common_bg'))
    .aspectRatio(1)
    .onClick(() => {
      this.controller.backward();
    })
  }
  .justifyContent(FlexAlign.SpaceAround)
  .width(CommonConstants.FULL_PERCENT)
  .height($r('app.float.navi_height'))
}
.width(CommonConstants.FULL_PERCENT)
.height(CommonConstants.FULL_PERCENT)
.backgroundColor($r('app.color.common_bg'))
.padding({ top: this.statusBarHeight - 1, bottom: this.sliderBarHeight })

} } 这种方式能够弹窗dialog。但是 如果我讲bridge的相关东西 抽象到一个类里面就不行了,抽象到下面的类中 然后再indexPage中new JSbridge 并设置 .javaScriptProxy(this.jsBridge.javaScriptProxy) 这样就弹不出来,不知道为什么

import WebView from ‘@ohos.web.webview’; import { ArkTSFunModel, BridgeProxy } from ‘…/…/model/ProductModel’; import { LogoutConfirmDialog } from ‘…/LogoutConfirmDialog’;

export default class JSBridge{ controller: WebView.WebviewController; constructor(controller: WebView.WebviewController) { this.controller = controller; }

arkTSObj: ArkTSFunModel = { jumpOrderConfirm: (detailStr: string) => this.jumpOrderConfirm(detailStr) };

get javaScriptProxy():BridgeProxy{ let proxy:BridgeProxy = { object:this.arkTSObj, name: ‘arkTSFunObj’, methodList: [‘jumpOrderConfirm’], controller: this.controller }; return proxy; }

jumpOrderConfirm(detailStr: string): string { this.logout() return “你点击了跳转111” }

dialogController?: CustomDialogController

private logout(){ if(!this.dialogController){ this.dialogController = new CustomDialogController({ builder: LogoutConfirmDialog({ cancel: ()=>{ }, controller:this.dialogController }), offset: {dx:0,dy:0}, autoCancel:true, customStyle:true, isModal:true, alignment: DialogAlignment.Center, // 可设置dialog的对齐方式,设定显示在底部或中间等,默认为底部显示 }) } this.dialogController?.open() } }

我也遇到了,调用原生方法不起作用

回到顶部