HarmonyOS学习(十)——网络编程

news2025/1/10 10:18:48

文章目录

        • 1、通过HTTP请求网络
        • 2、Web组件
          • 2.1、加载本地网页
          • 2.2、加载在线网页
          • 2.3、网页缩放
          • 2.4、文本缩放
          • 2.5、web组件事件以及状态说明
          • 2.6、处理页面导航

1、通过HTTP请求网络

官方API文档地址:HTTP数据请求-Network Kit数据传输能力-Network Kit(网络服务)-网络-系统 - 华为HarmonyOS开发者 (huawei.com)

接口地址:

https://route.showapi.com/109-34?appKey=B759f4a503eC4AB8BeA40f37C1AbF4E4

private httpReq(){
  //创建http请求
  let httpRequest = http.createHttp();
  //请求地址
  let requestUrl = "https://route.showapi.com/109-34?appKey=B759f4a503eC4AB8BeA40f37C1AbF4E4";
  //请求参数
  let options = {
    method:http.RequestMethod.GET,
    connectTimeout:6000,
    readTimeout:6000,
    header:{
      'content-Type':'application/json'
    }
  };
  let promise = httpRequest.request(
    requestUrl,
    options
  );
  //处理请求响应结果
  promise.then((data) => {
    if(data.responseCode == http.ResponseCode.OK){
      console.error('result:'+data.result);
      console.error('code:'+data.responseCode)
      this.message = JSON.stringify(data.result);
    }
  }).catch((err) => {
    console.error('error:'+JSON.stringify(err));
  })

}
  • 导入http模块。
import http from '@ohos.net.http';
  • 创建httpRequest对象,需要注意的是,每个httpRequest对象对应一个HTTP请求任务,不可重复。
//创建http请求
let httpRequest = http.createHttp();
  • 通过httpRequest对象发起HTTP请求。
//请求参数
let options = {
  method:http.RequestMethod.GET,
  connectTimeout:6000,
  readTimeout:6000,
  header:{
    'content-Type':'application/json'
  }
};
let promise = httpRequest.request(
  requestUrl,
  options
);
  • 处理HTTP请求返回的结果,并赋值给message变量。
//处理请求响应结果
promise.then((data) => {
  if(data.responseCode == http.ResponseCode.OK){
    console.error('result:'+data.result);
    console.error('code:'+data.responseCode)
    this.message = JSON.stringify(data.result);
  }
}).catch((err) => {
  console.error('error:'+JSON.stringify(err));
})
  • 界面重新渲染显示新的message变量值。
2、Web组件

官方文档地址:Web组件的生命周期-ArkWeb(方舟Web)-应用框架 - 华为HarmonyOS开发者 (huawei.com)

2.1、加载本地网页

将html存放在resource/rawfile/test.html

controller: webview.WebviewController = new webview.WebviewController();

build(){
  Column(){
    Web({
      src:$rawfile('test.html'),
      controller:this.controller
    })
  }
  .height('100%')
}

运行结果:

2.2、加载在线网页
controller: webview.WebviewController = new webview.WebviewController();

build(){
  Column(){
    Web({
      src:"https://www.baidu.com",
      controller:this.controller
    })
  }
  .height('100%')
}

需要再module.json5中加入权限说明:

"requestPermissions": [
  {
    "name": "ohos.permission.INTERNET",
    "reason": "$string:Use_net_reason",
    "usedScene": {
      "when": "inuse"
    }
  }
]

运行效果:

2.3、网页缩放

zoomAccess(zoomAccess: boolean) 设置是否支持手势进行缩放

Web({
  src:"https://www.baidu.com",
  controller:this.controller
})
  .zoomAccess(true)  //是否支持手势进行缩放

使用zoom(factor: number) 设置缩放大小

struct  webdemo1{

  //网页控制器
  controller: webview.WebviewController = new webview.WebviewController();
  @State zoomIndex:number = 1.5; //缩放倍数

  build(){
    Column(){
      Button('设置缩放')
        .type(ButtonType.Capsule)
        .onClick(() => {
          this.zoomIndex += 1.0;
          this.controller.zoom(this.zoomIndex)
        })
      Web({
        src:"https://www.baidu.com",
        controller:this.controller
      })
        .zoomAccess(true)  //是否支持手势进行缩放
    }
    .height('100%')
  }

运行效果

2.4、文本缩放
Web({
  src:$rawfile('test.html'),
  controller:this.controller,
})
  .textZoomRatio(500) // 文本缩放
  .zoomAccess(true)  //是否支持手势进行缩放
2.5、web组件事件以及状态说明
aboutToAppear函数在创建自定义组件的新实例后,在执行其build函数前执行。一般建议在此设置WebDebug调试模式setWebDebuggingAccess、设置Web内核自定义协议URL的跨域请求与fetch请求的权限customizeSchemes、设置CookieconfigCookie等
onControllerAttached事件当Controller成功绑定到Web组件时触发该回调,推荐在此事件中注入JS对象registerJavaScriptProxy、设置自定义用户代理setCustomUserAgent,可以在回调中使用loadUrl,getWebId等操作网页不相关的接口。但因该回调调用时网页还未加载,因此无法在回调中使用有关操作网页的接口,例如zoomIn、zoomOut等
onLoadIntercept事件当Web组件加载url之前触发该回调,用于判断是否阻止此次访问。默认允许加载
onOverrideUrlLoading事件当URL将要加载到当前Web中时,让宿主应用程序有机会获得控制权,回调函数返回true将导致当前Web中止加载URL,而返回false则会导致Web继续照常加载URL。onLoadIntercept接口和onOverrideUrlLoading接口行为不一致,触发时机也不同,所以在应用场景上存在一定区别。主要是在LoadUrl和iframe(HTML标签,表示HTML内联框架元素,用于将另一个页面嵌入到当前页面中)加载时,onLoadIntercept事件会正常回调到,但onOverrideUrlLoading事件在LoadUrl加载时不会触发,在iframe加载HTTP(s)协议或about:blank时也不会触发。详细介绍请见onLoadIntercept和onOverrideUrlLoading的说明
onInterceptRequest事件当Web组件加载url之前触发该回调,用于拦截url并返回响应数据
onPageBegin事件网页开始加载时触发该回调,且只在主frame(表示一个HTML元素,用于展示HTML页面的HTML元素)触发。如果是iframe或者frameset(用于包含frame的HTML标签)的内容加载时则不会触发此回调。多frame页面有可能同时开始加载,即使主frame已经加载结束,子frame也有可能才开始或者继续加载中。同一页面导航(片段、历史状态等)或者在提交前失败、被取消的导航等也不会触发该回调
onProgressChange事件告知开发者当前页面加载的进度。多frame页面或者子frame有可能还在继续加载而主frame可能已经加载结束,所以在onPageEnd事件后依然有可能收到该事件
onPageEnd事件网页加载完成时触发该回调,且只在主frame触发。多frame页面有可能同时开始加载,即使主frame已经加载结束,子frame也有可能才开始或者继续加载中。同一页面导航(片段、历史状态等)或者在提交前失败、被取消的导航等也不会触发该回调。推荐在此回调中执行JavaScript脚本loadUrl等。需要注意的是收到该回调并不能保证Web绘制的下一帧将反映此时DOM的状态
onRenderExited事件应用渲染进程异常退出时触发该回调, 可以在此回调中进行系统资源的释放、数据的保存等操作。如果应用希望异常恢复,需要调用loadUrl接口重新加载页面
onDisAppear事件组件卸载消失时触发此回调。该事件为通用事件,指组件从组件树上卸载时触发的事件
2.6、处理页面导航

使用浏览器浏览网页时,可以执行返回,前进,刷新等操作,web组件通过控制器也可以实现

this.controller.forward(); // 页面前进
this.controller.backward(); // 页面后退
this.controller.refresh(); //刷新页面
this.controller.clearHistory();// 清除历史

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

分类预测|基于雪消融优化BP神经网络的数据分类预测Matlab程序SAO-BP 多特征输入多类别输出 含基础程序

分类预测|基于雪消融优化BP神经网络的数据分类预测Matlab程序SAO-BP 多特征输入多类别输出 含基础程序 文章目录 一、基本原理二、实验结果三、核心代码四、代码获取五、总结 一、基本原理 SAO-BP模型结合了雪消融优化算法(SAO)和BP神经网络。以下是详细…

架空输电线路故障监测:可视精灵的导线全方位监测之道

集高科技与智能化于一身的“架空输电线路故障可视精灵”,以精准、高效、全面的监测能力,成为守护输电线路安全的得力助手,接下来,深圳鼎信智慧带您走近它: 技术概述 物联网(IoT):通…

神卓互联NAS助手SPK套件安装与使用指南

目录 一、SPK套件简介 二、安装前准备 三、安装步骤 1. 下载SPK套件 2. 安装SPK套件 3. 登录套件 四、使用指南 1. 创建访问映射规则 2. 外网访问 一、SPK套件简介 神卓互联NAS助手SPK套件,是专为群晖NAS设备设计的一款软件扩展包。采用先进的WanGooeTunn…

SpringBoot2:请求处理原理分析-接口参数解析原理(argumentResolvers)

一、知识回顾 我们知道,接口的参数,一般都要配上注解来一起使用。 不同的参数注解,决定了传参的方式不同。 为什么会这样? 如果让你设计接口参数解析,你会怎么做? 首先,我们知道方法参数是形…

双指针(8)_单调性_四数之和

个人主页:C忠实粉丝 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 C忠实粉丝 原创 双指针(8)_单调性_四数之和 收录于专栏【经典算法练习】 本专栏旨在分享学习C的一点学习笔记,欢迎大家在评论区交流讨论💌 目录 1. 题目…

QDY421F-16P-25液氨不锈钢液动紧急切断阀

一、产品概述 QDY421F-16P-25液氨不锈钢液动紧急切断阀,采用先进的液动驱动技术,结合高质量的不锈钢材质,专为满足液氨等腐蚀性介质的紧急切断需求而设计。该阀门的工作压力可达16MPa,适用于DN25(即25毫米)…

单向链表概述

文章目录 🍊自我介绍🍊单向链表概述数据域和指针域数据类型设计 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞关注评论收藏(一键四连)哦~ 🍊自我介绍 Hello,大家好,我是小珑也要…

高斯消元法

顾名思义就是我们初中所知的消元方程,用来解方程的,但是如果自己手动去实现的话,还是有一部分难度的,因此我们也会用到线代这门科目,因为这是实现计算自动化的关键步骤 现在这里放上高斯消元的板子(可以用…

正点原子阿尔法ARM开发板-IMX6ULL(四)——汇编LED驱动实验-下

文章目录 一、驱动编写1.1 配置GPIO的电气属性1.2 配置GPIO的功能(GDIR寄存器)1.3 设置输出(DR寄存器)1.4 最终代码 二、编译程序2.1 编译程序2.2 链接文件2.3 格式转换成BIN文件2.4 反汇编 三、烧写bin到SD卡中并运行3.1 准备工作…

中介者模式mediator

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/mediator 减少对象之间混乱无序的依赖关系。 该模式会限制对象之间的直接交互, 迫使它们通过一个中介者对象进行合作。

数据结构:树与二叉树(2)

1、线索二叉树 1.1线索二叉树的定义 (1)线索二叉树有啥用? 普通二叉树的节点包含左孩子和右孩子的信息,但并没有直接存储关于“直接前驱”和“直接后继”的信息,结点的前驱和后继只能在遍历过程中获得。 因此这里引…

Springboot中mybatis的使用

一.创建Springboot项目并加载依赖 1.利用IDEA创建SpringBoot项目,并勾选必须依赖,步骤如下(IDEA版本为2024版) 注意: 1.首先更换镜像源,否则加载配置环境比较慢,网上搜阿里的镜像源就行。 2…

关于在vue2中使用el-tree的记录

此文章会持续更新在使用el-tree过程中应用到的功能... 先看此效果&#xff1a; html&#xff1a; <el-tree :data"data" :props"defaultProps" node-click"handleNodeClick">//自定义节点内容<span slot-scope"{ data }"&g…

Leetcode面试经典150题-135.分发糖果

解法都在代码里&#xff0c;不懂就留言或者私信 阿里字节都考过 class Solution {/**对于每个孩子来说&#xff0c;我们试一下从左边开始它应该分几个糖果&#xff0c;然后看一下从右边开始它应该分几个糖果然后左右取最大值&#xff0c;每个位置求和就是我们要的答案 */publ…

【解决keil不能跳转函数声明的问题】

第一步&#xff1a;将魔术棒中的output选项里Browase Information功能打开 第二步&#xff1a;重新编译整个工程 第三步&#xff1a;跳转测试

Java项目: 基于SpringBoot+mybatis+maven实现的IT技术交流和分享平台(含源码+数据库+毕业论文)

一、项目简介 本项目是一套基于SpringBootmybatismaven实现的IT技术交流和分享平台 包含&#xff1a;项目源码、数据库脚本等&#xff0c;该项目附带全部源码可作为毕设使用。 项目都经过严格调试&#xff0c;eclipse或者idea 确保可以运行&#xff01; 该系统功能完善、界面美…

【笔记】2.1 石英类原料

2.1.1 石英类原料的种类 石英&#xff1a;结晶矿物。 &#xff08;1&#xff09;石英砂&#xff08;硅砂&#xff09; 石英石、长石在水、二氧化碳、温度作用下风化分解由水流冲击沉积而形成。 主要成分为&#xff0c;质地纯净的硅砂为白色&#xff0c;其中若含有少量杂质&…

SpringCloud集成MybatisPlus,实现MySQL多数据源配置

引入依赖 <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.0</version> </dependency><dependency><groupId>com.alibaba</groupId><art…

Apache DataFusion查询引擎简介

01 简介 DataFusion是一个查询引擎&#xff0c;其本身不具备存储数据的能力。正因为不依赖底层存储的格式&#xff0c;使其成为了一个灵活可扩展的查询引擎。它原生支持了查询CSV&#xff0c;Parquet&#xff0c;Avro&#xff0c;Json等存储格式&#xff0c;也支持了本地&#…

TCP通信实现

前言 TCP&#xff08;Transmission Control Protocol&#xff0c;传输控制协议&#xff09;是一种面向连接的、可靠的、基于流的通信协议。它是互联网协议栈&#xff08;TCP/IP&#xff09;中的核心协议之一&#xff0c;主要用于保证在计算机网络中可靠地传输数据。 TCP通信的基…