【鸿蒙学习笔记】使用axios进行HTTP数据请求

官方文档:网络管理开发概述

目录标题

访问淘宝公开接口(测试数据)

http://rap2api.taobao.org/app/mock/293606/api/chat/list

第1步:module.json5 配置网络授权

cpp 复制代码
"requestPermissions": [{
  // 网络授权
  "name":'ohos.permission.INTERNET'
}]

第2步:下载axios

Alt+F12 → 执行 ohpm install @ohos/axios


第3步:源码

cpp 复制代码
//1. 下载axios: Alt+F12 → 执行 ohpm install @ohos/axios
//2. 导入axios
import axios, { AxiosError, AxiosResponse } from '@ohos/axios'

class DataInfo {
  list: Array<DataItem> = new Array()
  // list: Array<DataItem> = []
}

class DataItem {
  originName: string = ''
  messageIconUrl: string = ''
  describe: string = ''
  remarkName: string = ''
  messageText: string = ''
}

// 淘宝公开接口,返回的数据读不懂(测试数据)
let url = 'http://rap2api.taobao.org/app/mock/293606/api/chat/list';

@Entry
@Component
struct Page_axios {
  @State mockDataList: Array<DataItem> = []
  url = 'http://rap2api.taobao.org/app/mock/293606/api/chat/list';

  build() {
    Row() {
      Column() {
        Button('get axiosData').margin(20)
          .onClick(() => {
            this.getAxiosData()
          })
        ForEach(this.mockDataList, (item: DataItem) => {
          Text(item.originName).fontColor(Color.Red)
        })

        Button('使用Axios获取网络数据').margin(20)
          .onClick(() => {
            this.axiosGetHttpData();
          })
        ForEach(this.mockDataList, (item: DataItem) => {
          Text(item.originName).fontColor(Color.Blue)
        })
      }.width('100%')
    }.height('100%')
  }

  getAxiosData() {
    //3. axios发起请求
    axios.get(this.url)
      .then((res: AxiosResponse) => {
        //4. axios获取结果
        // res.data
        AlertDialog.show({ message: JSON.stringify(res.data) })
        this.mockDataList = res.data.list
      })
  }

  axiosGetHttpData() {
    axios.get<DataInfo, AxiosResponse<DataInfo>, null>(url)
      .then((resp: AxiosResponse<DataInfo>) => { // 获取数据成功
        if (resp.status === 200) { // 获取正确网络数据
          AlertDialog.show({ message: JSON.stringify(resp.data.list) })
          this.mockDataList = resp.data.list
        } else {
          AlertDialog.show({ message: '获取失败' })
        }
      })
      .catch((err: AxiosError) => { // 网络异常或者接口异常回调
        AlertDialog.show({ message: '获取失败' })
      })
  }
}

第4步:启动模拟器

第5步:启动entry

第6步:操作

相关推荐
程序员潘Sir18 分钟前
鸿蒙应用开发从入门到实战(九):ArkTS渲染控制
harmonyos·鸿蒙
HarmonyOS_SDK16 小时前
Account Kit(华为账号服务)再进化,开发者接入效率飙升!
harmonyos
whysqwhw1 天前
鸿蒙 任意类型转字符串
harmonyos
使一颗心免于哀伤1 天前
《设计模式之禅》笔记摘录 - 21.状态模式
笔记·设计模式
程序员潘Sir1 天前
鸿蒙应用开发从入门到实战(八):ArkTS自定义组件语法
harmonyos·鸿蒙
高心星2 天前
鸿蒙5.0应用开发——V2装饰器@Provider和@Consumer的使用
harmonyos
ChinaDragon2 天前
HarmonyOS:ArkTS卡片页面刷新
harmonyos
HMSCore2 天前
通知语音播报功能,解锁全新体验
harmonyos
HarmonyOS_SDK2 天前
通知语音播报功能,解锁全新体验
harmonyos