HarmonyOS Web组件解析html文本解析不出来

这一段解析不出来

<font color='#FF8012'><a style='color:#FF8012'>哈哈哈</a></font>
  • 1.
HarmonyOS
2024-12-25 14:57:38
浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
Excelsior_abit

若html中的富文本中带有注入#等特殊字符,建议使用带有两个空格的loadData函数,将baseUrl和historyUrl置为空。

参考链接:https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/js-apis-webview-V5#loaddata

demo如下

// xxx.ets
import web_webview from '@ohos.web.webview';
import business_error from '@ohos.base';

@Entry
@Component
struct WebComponent {
  controller: web_webview.WebviewController = new web_webview.WebviewController();

  build() {
    Column({space:30}) {
      Button('loadData with #')
        .onClick(() => {
          try {

            // 点击按钮时,通过loadData,加载HTML格式的文本数据
            this.controller.loadData(
              "<html><body bgcolor=\"white\"><div><span style= \"color:#0909F7\" >测试测试测试测试测试</span></div></body></html>",
              "text/html",
              "UTF-8",
              " ",
              " "
            );
          } catch (error) {
            let e: business_error.BusinessError = error as business_error.BusinessError;
            console.error(`ErrorCode: ${e.code}, Message: ${e.message}`);
          }
        })

      Button('loadData without #')
        .onClick(() => {
          try {
            // 点击按钮时,通过loadData,加载HTML格式的文本数据
            this.controller.loadData(
              "<html>" +
                "<body bgcolor=\"white\">" +
                "<div>" +
                "<span style=\"color: rgb(255,100,100);\">" +
                "测试测试测试测试测试测试" +
                "</span>" +
                "</div>" +
                "</body>" +
                "</html>",
              "text/html",
              "UTF-8"
            );
          } catch (error) {
            let e: business_error.BusinessError = error as business_error.BusinessError;
            console.error(`ErrorCode: ${e.code}, Message: ${e.message}`);
          }
        })
      // 组件创建时,加载www.index.com
      Web({ src: 'www.index.com', controller: this.controller })
    }
    .width("100%").height("100%").justifyContent(FlexAlign.Center)
  }
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.
  • 54.
  • 55.
  • 56.
  • 57.
分享
微博
QQ
微信
回复
2024-12-25 17:27:45
相关问题
HarmonyOS 加载html,图片显示不出来
1001浏览 • 1回复 待解决
HarmonyOS web组件接入链接渲染不出来
729浏览 • 1回复 待解决
HarmonyOS 如何解析HTML文本
1391浏览 • 1回复 待解决
HarmonyOS Html文本标签解析
805浏览 • 1回复 待解决
HarmonyOS scrollbar显示不出来
779浏览 • 1回复 待解决
HarmonyOS 地图加载不出来
1060浏览 • 1回复 待解决
Text怎么解析展示带html标签的文本
2866浏览 • 1回复 待解决
HarmonyOS Lottie动画加载不出来
890浏览 • 1回复 待解决
HiLog日志打印不出来?
12248浏览 • 3回复 已解决
HarmonyOS Text组件文本解析问题
847浏览 • 1回复 待解决
开启混淆后,卡片加载不出来
7222浏览 • 1回复 待解决
HarmonyOS 地图加载不出来,只显示背景
1867浏览 • 1回复 待解决
HarmonyOS 原生解析html的诉求
833浏览 • 1回复 待解决
HarmonyOS list最后一个显示不出来
965浏览 • 1回复 待解决