鸿蒙(HarmonyOS)应用开发——web组件

简述

在开发的工作中,可能存在一个场景,我们有一个问卷调查的h5页面,需要切入到app 中。这个时候,就需要从app 端操作,切换到web端操作。不管是安卓、ios、小程序都提供有web组件。那么harmonyos 中也提供web组件来在应用内加载浏览器

语法

javascript 复制代码
web(options:{src:string, controller?:WebController})

src

设置网页资源地址,可以是本地资源,也可以是网络资源;

  • 本地资源
    src:$rawfile('index.html')
  • 网络资源
    网络资源需添加网络权限:ohos.permission.INTERNET

controller控制器

可以控制web组件的各种行为,如前进、后退等操作

forward

按照历史栈,前进一个页面

backward

按照历史栈,后退一个页面

runJavaScript

异步执行javascript脚本,病通过回调方式返回脚本执行的结果

  • 在main/resource/rawfile目录下新建index.html页面
javascript 复制代码
function test(){
 console.log(111)
}
  • web组件调用runJavaScript方法可以执行html中的javascript脚本
javascript 复制代码
controller: WebController = new WebController();
Button().
	onclick(()=>{
		this.controller.runJavaScript({script: 'test()'})
})

支持的属性

属性 fileAccess javaScriptAccess imageAccess zoomAccess textZoomAtio ....

  • fileAccess

    fileAccess(boolean): 设置是否开启通过$rawfile('filepath/filename')访问应用中的rawfile路径的文件。默认时启用

  • javaScriptAccess

    javaScriptAccess(boolean): 设置是否运行执行javascript脚本

  • imageAccess

    imageAccess(boolean): 设置是否允许自动加载图片资源

  • zoomAccess

    zoomAccess(boolean): 用于设置是否支持手势进行缩放,默认允许执行缩放;但是这个要求,网页自身支持缩放,这个属性才会生效。

  • textZoomAtio

    textZoomAtio(number): 用于设置页面的文本缩放百分比,默认值为100,表示100%。

支持方法

  • onConfirm
  • onAlert
  • onBeforeUnload
  • onConsole
相关推荐
前端世界5 分钟前
在鸿蒙中实现实时语音与视频传输:架构思路 + 可跑 Demo 全解析
架构·音视频·harmonyos
前端不太难8 分钟前
HarmonyOS 为何用 Ability 约束游戏?
游戏·状态模式·harmonyos
时光追逐者9 分钟前
一个基于 .NET + Vue 实现的通用权限管理平台(RBAC模式),前后端分离模式,开箱即用!
前端·vue.js·c#·.net·.net core
森之鸟9 分钟前
【鸿蒙安全架构深入解析:从国测Ⅱ级认证到星盾架构实战】
架构·harmonyos·安全架构
Aotman_11 分钟前
Vue el-table 表尾合计行
前端·javascript·vue.js·elementui·前端框架·ecmascript
一起养小猫13 分钟前
Flutter for OpenHarmony 进阶:Socket通信与网络编程深度解析
网络·flutter·harmonyos
前端世界13 分钟前
鸿蒙应用如何集成第三方 SDK?真实项目中的完整实践
华为·harmonyos
摘星编程14 分钟前
React Native鸿蒙:ProgressBar圆角进度条
react native·react.js·harmonyos
静小谢18 分钟前
vue3实现语言切换vue-i18n
前端·javascript·vue.js
人工智能知识库22 分钟前
华为HCIP-Datacom H12-821题库(带详细解析)
华为·hcip-datacom·h12-821·华为数通·h12-821题库