ArkWeb页面跳转与跨应用导航 - 高级应用

news/2024/10/18 15:48:45/文章来源:https://www.cnblogs.com/samex/p/18474400

本文旨在深入探讨华为鸿蒙HarmonyOS Next系统(截止目前API12)的技术细节,基于实际开发实践进行总结。
主要作为技术分享与交流载体,难免错漏,欢迎各位同仁提出宝贵意见和问题,以便共同进步。
本文为原创内容,任何形式的转载必须注明出处及原作者。

简介

页面跳转是Web应用中常见的操作,可以引导用户浏览不同的页面内容。ArkWeb框架提供了多种方式实现页面跳转,包括拦截页面跳转请求和使用ArkUI的router模块。本文将深入介绍这些方法,并提供一些代码示例。

页面跳转

跳转到应用内其他页面

您可以使用onLoadIntercept接口拦截页面跳转请求,并根据URL进行页面跳转。例如,您可以在应用的首页拦截所有以native://开头的URL,并跳转到相应的页面:

Web({ src: $rawfile("index.html") }).onLoadIntercept((event) => {if (event.data.getRequestUrl().startsWith("native://")) {const targetPage = event.data.getRequestUrl().substring(9);// 跳转到目标页面,并传递参数router.pushUrl({url: targetPage,params: {key1: "value1",key2: "value2"}});return true; // 拦截并处理页面跳转}return false; // 允许页面跳转});

在这段代码中,我们首先检查URL是否以native://开头。如果是,我们使用router.pushUrl方法跳转到目标页面,并传递参数。返回true表示拦截并处理页面跳转,返回false表示允许页面跳转。

跳转到其他应用

您可以使用ArkUI的router模块进行跨应用导航。例如,您可以使用以下代码跳转到系统设置应用:

import { router } from '@ohos.arkui';
router.gotoApp({package: "com.example.systemsettings",ability: "com.example.systemsettings.MainAbility",params: {key1: "value1",key2: "value2"}
});

在这段代码中,我们指定了目标应用的包名和入口页面的ability,并传递了参数。您需要替换为实际的目标应用信息。

使用Intent过滤器

您可以使用Intent过滤器进行跨应用导航。例如,您可以使用以下代码打开地图应用并搜索特定地点:

import { Intent } from '@ohos.arkui';
const intent = new Intent();
intent.setAction("android.intent.action.VIEW");
intent.setData("geo:37.7749,-122.4194"); // 地理坐标
Intent.startActivity(intent);

在这段代码中,我们创建了一个Intent对象,并设置了action和数据。您需要替换为实际的目标应用信息和搜索地点。

跨应用导航

使用arkui.Intent模块

您可以使用arkui.Intent模块进行跨应用导航。例如,您可以使用以下代码打开电话应用并拨打电话:

import { Intent } from '@ohos.arkui';
const intent = new Intent();
intent.setAction("android.intent.action.DIAL");
intent.setData("tel:1234567890"); // 电话号码
Intent.startActivity(intent);

在这段代码中,我们创建了一个Intent对象,并设置了action和数据。您需要替换为实际的目标应用信息和电话号码。

使用arkui.PackageManager模块

您可以使用arkui.PackageManager模块获取应用信息,例如包名和版本号。例如:

import { PackageManager } from '@ohos.arkui';
PackageManager.getPackageInfo({packageName: "com.example.systemsettings",success: (info) => {console.log("Package name: " + info.packageName);console.log("Version name: " + info.versionName);console.log("Version code: " + info.versionCode);},fail: (error) => {console.log("Error: " + error.message);}
});

在这段代码中,我们指定了目标应用的包名,并获取了包名、版本名和版本号。您需要替换为实际的目标应用包名。

示例代码

以下示例代码展示了如何使用onLoadIntercept接口跳转到应用内其他页面,以及如何使用router模块和Intent过滤器跳转到其他应用:

import { webview } from '@ohos.web.webview';
import { router } from '@ohos.arkui';
import { Intent } from '@ohos.arkui';
@Entry
@Component
struct WebComponent {controller: webview.WebviewController = new webview.WebviewController();build() {Column() {// 跳转到应用内其他页面Web({ src: $rawfile("index.html") }).onLoadIntercept((event) => {if (event.data.getRequestUrl().startsWith("native://")) {const targetPage = event.data.getRequestUrl().substring(9);// 跳转到目标页面,并传递参数router.pushUrl({url: targetPage,params: {key1: "value1",key2: "value2"}});return true; // 拦截并处理页面跳转}return false; // 允许页面跳转});// 跳转到其他应用Web({ src: $rawfile("index.html") }).onLoadIntercept((event) => {if (event.data.getRequestUrl().startsWith("tel://")) {const phoneNumber = event.data.getRequestUrl().substring(6);// 使用Intent过滤器打开电话应用并拨打电话const intent = new Intent();intent.setAction("android.intent.action.DIAL");intent.setData("tel:" + phoneNumber);Intent.startActivity(intent);return true; // 拦截并处理页面跳转}return false; // 允许页面跳转});}}
}

总结

通过掌握ArkWeb框架中的页面跳转和跨应用导航方法,您可以轻松地实现Web应用的页面跳转功能,并引导用户浏览不同的页面内容,甚至跳转到其他应用。希望本文提供的示例代码能够帮助您更好地理解和应用这些功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/816912.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenCity: Open Spatio-Temporal Foundation Models for Traffic Prediction

1. 数据准备 在这个数据处理过程中,以数据集 PEMS07M 为例,整个数据抽取和划分过程如下:初始数据维度:原始训练数据 data_train 的维度为 (12672, 228, 3)。其中:12672 表示时间步数,代表不同的时间点采样的数据。 228 表示空间节点数(例如不同的交通站点)。 3 表示每个…

04C++顺序结构(3)

1、设置域宽setw(); 2、cin语句; 3、输入输出.格式化一、设置域宽setw() 输出的内容所占的总宽度成为域宽,有些高级语言中称为场宽。 使用setw()前,必须包含头文件iomanip,即#include<iomanip> 头文件iomanip,用来声明一些“流操作符”,需要一定格式输入输出时,就…

轻松上手-MVVM模式_关系型数据库_云函数T云数据库

作者:狼哥 团队:坚果派 团队介绍:坚果派由坚果等人创建,团队拥有12个华为HDE带领热爱HarmonyOS/OpenHarmony的开发者,以及若干其他领域的三十余位万粉博主运营。专注于分享HarmonyOS/OpenHarmony、ArkUI-X、元服务、仓颉。团队成员聚集在北京,上海,南京,深圳,广州,宁…

九宫格自由流转拼图游戏

作者:狼哥 团队:坚果派 团队介绍:坚果派由坚果等人创建,团队拥有12个华为HDE带领热爱HarmonyOS/OpenHarmony的开发者,以及若干其他领域的三十余位万粉博主运营。专注于分享HarmonyOS/OpenHarmony、ArkUI-X、元服务、仓颉。团队成员聚集在北京,上海,南京,深圳,广州,宁…

数据预处理-DataFrame切片

此Blog仅作为日常学习工作中记录使用,Blog中有不足之处欢迎指出 以kaggle中房屋预测的训练集为例,说明DataFrame切片常用操作 一、读入数据 import numpy as np import pandas as pdfile_path = ***\kaggle_house_pred_train.csv data = pd.read_csv(file_path)data.columns …

轻松上手-Navigation路由 H5

作者:狼哥 团队:坚果派 团队介绍:坚果派由坚果等人创建,团队拥有12个华为HDE带领热爱HarmonyOS/OpenHarmony的开发者,以及若干其他领域的三十余位万粉博主运营。专注于分享HarmonyOS/OpenHarmony、ArkUI-X、元服务、仓颉。团队成员聚集在北京,上海,南京,深圳,广州,宁…

Audio

音频文件导入 常用格式wav mp3 aiff音频文件属性设置Force To Mono:多声道转单声道; Normalize:强制为单声道时,混合过程中被标准化 Load In Background:在后台加载时,不阻塞主线程 Ambisonic:立体混响声,非常适合360度视频和XR应用程序,如果音频文件包含立体混响声编…

RenderTexture

基础概念 RenderTexture 在Unity中,RenderTexture是一种纹理,它可以在运行时动态地生成图像数据,并且可以作为着色器的输入或者显示在游戏世界的任何材质上。简单来说,RenderTexture让你能够将场景或特定相机的渲染结果捕获到一个纹理中,然后这个纹理可以被用作其他渲染过…

九点共圆及其圆心证明(证明过程已更新)

九点共圆及其圆心证明主要思路:固定 \(P,L\),证明其它七个点均在以 \(PL\) 为直径的圆上。 条件的来源会备注在括号内。背景可能影响观感,建议打开极简模式阅读。这是一个三角形 \(\triangle ABC\),设 \(BC,AC,AB\) 边上垂足分别为 \(D,E,F\),其边上中点分别为 \(L,M,N\),…

【喜讯】全球电商大数据平台推出F类免费API接口服务!

好消息,全球电商大数据平台再次上线多个类别接口,首次推出F类免费API接口服务,为所有追求数据赋能、寻求创新突破的企业和个人,带来了前所未有的机遇。好消息,值此之际;全球电商大数据平台再次上线多个类别接口,首次推出F类免费API接口服务,为所有追求数据赋能、寻求创…

c# winform在线升级clickonce

说明:在线升级前提 1,一个可以访问在线的地址,2,发布前要在项目属性发布里配置好相关设置 一,可以在IIS上布署一个可以访问的地址 二,发布前配置

SQLSEVER 实现货币数字转中文汉字

SQLSEVER 实现数字转换成中文(货币) -- ============================================= -- Author: LearnerPing -- Create date: 2024/10/18 -- Description: Change Number to Chinese -- ============================================= Create FUNCTION GetNumberToChi…