第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

HarmonyOS NEXT ArkTS與H5的交互詳解

ArkTS与H5的交互实现:JSBridge桥接机制详解

在现代移动应用开发中,ArkTS(ArkUI框架的TypeScript实现)与H5的交互是一个常见的需求。为了实现这种跨平台的交互,开发者通常需要借助JSBridge桥接机制。本文将详细介绍如何在ArkTS侧与H5之间建立JSBridge桥接,并通过具体的代码示例展示如何实现双向通信。

1. JSBridge桥接机制概述

JSBridge是一种用于连接原生代码(如ArkTS)与Web页面(H5)的桥梁。通过JSBridge,H5页面可以调用原生功能,而原生代码也可以将数据传递回H5页面。这种机制的核心在于通过JavaScript与原生代码的交互,实现双向通信。

在ArkTS与H5的交互中,JSBridge的主要职责是:

  • 在ArkTS侧封装调用方法,供H5调用。

  • 在H5侧提供调用原生方法的接口。

  • 处理异步回调,将原生代码的执行结果返回给H5。

2. 初始化JSBridge

首先,我们需要在ArkTS侧定义一个JSBridge类,并在其中封装call方法和initJsBridge方法。initJsBridge方法的作用是将JSBridge初始化脚本注入到H5页面中,以便H5能够调用原生方法。

// CodeConstant.etsexport const code = `
const JSBridgeMap = {};
let callID = 0;
// 执行H5回调函数
function JSBridgeCallback (id, params) {
    JSBridgeMap[id](params);
    JSBridgeMap[id] = null;
    delete JSBridgeMap[id];
}

// 在window中声明callNative方法供H5调用
window.ohosCallNative = {
    callNative(method, params, callback) {
        const id = callID++;
        const paramsObj = {
            callID: id,
            data: params || null
        }
        JSBridgeMap[id] = callback || (() => {});
        JSBridgeHandle.call(method, JSON.stringify(paramsObj));
    }
}

在上述代码中,JSBridgeMap用于存储H5侧的回调函数,callID用于标识每次调用的唯一性。ohosCallNative对象是H5调用原生方法的入口,H5通过调用callNative方法,将方法名、参数以及回调函数传递给ArkTS侧。

3. 注入JavaScript对象到H5

接下来,我们需要通过Web组件的javaScriptProxy属性,将ArkTS侧的JSBridgeHandle对象注册到H5的window对象中。这样,H5就可以通过window.JSBridgeHandle调用ArkTS侧的方法。

// JsBridge.etsexport default class JsBridge {
    get javaScriptProxy(): JavaScriptItem {
        return {
            object: {
                call: this.call            },
            name: "JSBridgeHandle",
            methodList: ['call'],
            controller: this.controller        } as JavaScriptItem;
    }
}// SelectContact.ets@Entry@Componentstruct SelectContact {
    webController: WebView.WebviewController = new WebView.WebviewController();
    private jsBridge: JSBridge = new JSBridge(this.webController);
    build() {
        Column() {
            Web({
                src: $rawfile('MainPage.html'),
                controller: this.webController            })
            .javaScriptAccess(true)
            .javaScriptProxy(this.jsBridge.javaScriptProxy)
        }
    }
}

在上述代码中,javaScriptProxy属性将JSBridgeHandle对象注入到H5的window对象中,H5可以通过window.JSBridgeHandle.call调用ArkTS侧的方法。

4. 实现call方法及回调

在ArkTS侧,call方法是H5调用原生方法的统一入口。根据H5传递的方法名,ArkTS侧会执行相应的逻辑,并通过callback方法将结果返回给H5。

// JsBridge.etsexport default class JsBridge {
    call = (func: string, params: string): void => {
        const paramsObject: ParamsItem = JSON.parse(params);
        let result: Promise<string>;
        switch (func) {
            case 'chooseContact':
                result = this.chooseContact();
                break;
            default:
                break;
        }
        result.then((data: string) => {
            this.callback(paramsObject?.callID, data);
        })
    }
    callback = (id: number, data: string): void => {
        this.controller.runJavaScript(`JSBridgeCallback("${id}", ${JSON.stringify(data)})`);
    }
}

call方法中,ArkTS侧根据H5传递的方法名执行相应的逻辑,并通过callback方法将结果回传给H5。callback方法通过runJavaScript执行H5侧的回调函数,将数据传递回H5。

5. H5调用ArkTS侧方法

在H5侧,只需要调用ohosCallNative.callNative方法,将方法名、参数以及回调函数传递给ArkTS侧即可。

// mainPage.jsfunction chooseContact() {
    window.ohosCallNative.callNative('chooseContact', {}, (data) => {
        console.log(data);
    });
}

在上述代码中,H5通过ohosCallNative.callNative调用ArkTS侧的chooseContact方法,并在回调函数中处理返回的数据。

6. 总结

通过上述步骤,我们成功实现了ArkTS与H5之间的JSBridge桥接机制。ArkTS侧通过javaScriptProxy将方法注入到H5,H5通过ohosCallNative调用ArkTS侧的方法,并通过回调函数接收异步返回的数据。这种机制不仅实现了跨平台的交互,还为开发者提供了灵活的双向通信能力。

在实际开发中,开发者可以根据业务需求扩展JSBridge的功能,例如增加更多的方法调用、处理复杂的参数传递等。通过JSBridge,ArkTS与H5的交互将变得更加高效和便捷。


點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消