鸿蒙5.0开发【自定义全局组件 UI 构建异常问题和解决】

在之前的文章中([鸿蒙自定义 Dialog 的 6 种方式]),提到了自定义 Dialog 某些情况下无法渲染显示的问题,其本质是 UI 组件构造时,UI 上下文获取异常,一般在异步回调或者非 UI 组件环境中构造全局类的组件(例如弹窗或者 HUD)时,容易遇到这个问题。

1. 问题复现

使用我的 [XTEasyHUD],不预先在 UI 组件生命周期中对其进行初始化配置,直接在异步场景中调用,就会导致 HUD 无法显示。

ts
 代码解读
复制代码
import axios, { AxiosResponse } from '@ohos/axios'
import {
  XTEasyHUD
} from '@jxt/xt_hud'

class viewModel {
  async asyncShowToast() {
    let response: AxiosResponse<string> = await axios.get('https://www.baidu.com')
    console.log('end', response.data)
    // 这个 toast 无法显示
    XTEasyHUD.showToast('请求完成')
  }
}

@Entry
@Component
struct Index {
  vm: viewModel = new viewModel()
  build() {
    Column() {
      Button('异步显示 Toast')
        .onClick(() => {
          this.vm.asyncShowToast()
        })
    }
    .height('100%')
    .width('100%')
  }
}

我在该组件库的文档中,有做该问题的特别说明和解决方案描述:[已知问题特别注意]

解决方案:

import axios, { AxiosResponse } from '@ohos/axios'
import {
  XTEasyHUD
} from '@jxt/xt_hud'

class viewModel {
  async asyncShowToast() {
    let response: AxiosResponse<string> = await axios.get('https://www.baidu.com')
    console.log('end', response.data)
    XTEasyHUD.showToast('请求完成')
  }
}

@Entry
@Component
struct Index {
  vm: viewModel = new viewModel()

  // Warning: 强烈建议在全局根页面组件中事先做一次XTEasyHUD的全局配置,如果使用默认样式,可以直接进行空配置
  // 这样可以保证后续使用时,异步场景中的 HUD 可以正常加载
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值