0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Web页面白屏问题的排查步骤和解决方法

HarmonyOS开发者 ? 来源:HarmonyOS开发者技术 ? 2025-08-22 10:49 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

Web页面出现白屏的原因众多,本文列举了若干常见白屏问题的排查步骤,供开发者快速定位。

1.首先排查权限和网络状态。

2.通过使用DevTools工具调试前端页面定位具体报错类型(跨域、资源404、JS异常)。

3.在复杂布局场景中,排查渲染模式及组件约束条件的问题。

4.处理H5代码兼容性问题。

5.从日志中排查生命周期和网络加载相关关键字。

检查权限和网络状态

如果应用未开启联网或文件访问权限或者设备网络状态不佳,将导致Web组件加载失败或页面元素缺失,进而引起白屏。

验证设备的网络状态,包括是否已连接网络,设备自带的浏览器能否正常访问网页等(在线页面场景)。

确保应用已添加网络权限:ohos.permission.INTERNET(在线页面必需)。

// 在module.json5中添加相关权限
"requestPermissions":[
 {
  "name":"ohos.permission.INTERNET"
 }
]

开启相关权限:

d132f0a4-7d9c-11f0-a18e-92fbcf53809c.png

// xxx.ets
import{ webview }from'@kit.ArkWeb';
@Entry
@Component
structWebComponent{
controller: webview.WebviewController=newwebview.WebviewController();
build() {
 Column() {
  Web({src:'www.example.com',controller:this.controller})
    .domStorageAccess(true)
    .fileAccess(true)
    .imageAccess(true)
    .onlineImageAccess(true)
    .javaScriptAccess(true)
  }
 }
}

修改UserAgent后再观察页面是否恢复正常。

// xxx.ets
import{ webview }from'@kit.ArkWeb';
import{BusinessError}from'@kit.BasicServicesKit';
@Entry
@Component
structWebComponent{
controller: webview.WebviewController=newwebview.WebviewController();
@StatecustomUserAgent:string=' DemoApp';
build() {
 Column() {
  Web({src:'www.example.com',controller:this.controller})
   .onControllerAttached(() =>{
   console.log("onControllerAttached");
   try{
    letuserAgent =this.controller.getUserAgent() +this.customUserAgent;
    this.controller.setCustomUserAgent(userAgent);
    }catch(error) {
    console.error(`ErrorCode:${(errorasBusinessError).code}, Message:${(errorasBusinessError).message}`);
    }
   })
  }
 }
}

使用DevTools工具进行页面内容验证

在确保网络与权限配置无误后,若仍出现白屏,则应利用DevTools工具调试前端页面以及监听Web相关错误上报接口,来定位具体报错类型。

1.查阅控制台的错误信息,定位具体的资源加载失败问题。资源加载失败会导致页面元素缺失,布局紊乱,图片和动画效果失效等,严重时可能导致渲染进程崩溃,页面呈现空白。如图所示,依次排查:

(1)元素是否完整,html元素、结构是否正确。

(2)控制台是否有报错。

(3)网络里面是否有资源加载时间特别长等。

d1499fde-7d9c-11f0-a18e-92fbcf53809c.png

2.检查控制台,确认是否存在因MixedContent策略或CORS策略导致的异常,或JS错误等。可参考解决Web组件本地资源跨域问题。为了提高安全性,ArkWeb内核禁止file协议和resource协议访问跨域请求。因此,在使用Web组件加载本地离线资源的时候,Web组件会拦截file协议和resource协议的跨域访问。Web组件无法访问本地跨域资源时,DevTools控制台会显示报错信息:

Accesstoscriptat'xxx'fromorigin'xxx'has been blockedbyCORS policy:Crossorigin requestsareonlysupportedforprotocol schemes:  http, arkweb, data, chrome-extension, chrome, https, chrome-untrusted.

有如下两种解决方法:

方法一:

开发者应使用http或https协议替代file或resource协议,确保Web组件能够成功访问跨域资源。替代的URL域名应为自定义构造,仅限于个人或组织使用,以防止与互联网上的实际域名冲突。此外,开发者需要利用Web组件的onInterceptRequest方法,对本地资源进行拦截和相应替换。

以下结合示例说明如何使用http或者https等协议解决本地资源跨域访问失败的问题。其中,index.html和js/script.js文件置于工程的rawfile目录下。当使用resource协议访问index.html时,js/script.js文件因跨域而被拦截,无法加载。在示例中,使用https://www.example.com/域名替换了原有的resource协议,同时利用onInterceptRequest接口替换资源,确保js/script.js文件可以成功加载,从而解决跨域拦截问题。

// main/ets/pages/Index.ets
import{ webview }from'@kit.ArkWeb';
@Entry
@Component
structIndex{
@Statemessage:string='Hello World';
webviewController: webview.WebviewController=newwebview.WebviewController();
// 构造域名和本地文件的映射表
 schemeMap =newMap([
  ["https://www.example.com/index.html","index.html"],
  ["https://www.example.com/js/script.js","js/script.js"],
 ])
// 构造本地文件和构造返回的格式mimeType
 mimeTypeMap =newMap([
  ["index.html",'text/html'],
  ["js/script.js","text/javascript"]
 ])
build() {
 Row() {
  Column() {
   // 针对本地index.html,使用http或者https协议代替file协议或者resource协议,并且构造一个属于自己的域名。
   // 本例中构造www.example.com为例。
   Web({src:"https://www.example.com/index.html",controller:this.webviewController})
     .javaScriptAccess(true)
     .fileAccess(true)
     .domStorageAccess(true)
     .geolocationAccess(true)
     .width("100%")
     .height("100%")
     .onInterceptRequest((event) =>{
     if(!event) {
      return;
      }
     // 此处匹配自己想要加载的本地离线资源,进行资源拦截替换,绕过跨域
     if(this.schemeMap.has(event.request.getRequestUrl())) {
      letrawfileName:string=this.schemeMap.get(event.request.getRequestUrl())!;
      letmimeType =this.mimeTypeMap.get(rawfileName);
      if(typeofmimeType ==='string') {
       letresponse =newWebResourceResponse();
       // 构造响应数据,如果本地文件在rawfile下,可以通过如下方式设置
        response.setResponseData($rawfile(rawfileName));
        response.setResponseEncoding('utf-8');
        response.setResponseMimeType(mimeType);
        response.setResponseCode(200);
        response.setReasonMessage('OK');
        response.setResponseIsReady(true);
       returnresponse;
       }
      }
     returnnull;
     })
   }
   .width('100%')
  }
  .height('100%')
 }
}
 


 



// main/resources/rawfile/js/script.js
constbody =document.body;
constelement =document.createElement('div');
element.textContent='success';
body.appendChild(element);

方法二:

通过setPathAllowingUniversalAccess设置一个路径列表。当使用file协议访问该列表中的资源时,允许进行跨域访问本地文件。此外,一旦设置了路径列表,file协议将仅限于访问列表内的资源(此时,fileAccess的行为将会被此接口行为覆盖)。路径列表中的路径应符合以下任一路径格式:

1.应用文件目录通过Context.filesDir获取,其子目录示例如下:

/data/storage/el2/base/files/example

/data/storage/el2/base/haps/entry/files/example

2.应用资源目录通过Context.resourceDir获取,其子目录示例如下:

/data/storage/el1/bundle/entry/resource/resfile

/data/storage/el1/bundle/entry/resource/resfile/example

当路径列表中的任一路径不满足上述条件时,系统将抛出异常码401,并判定路径列表设置失败。如果路径列表设置为空,file协议的可访问范围将遵循fileAccess规则,具体示例如下。

// main/ets/pages/Index.ets
import{ webview }from'@kit.ArkWeb';
import{BusinessError}from'@kit.BasicServicesKit';
@Entry
@Component
structWebComponent{
controller:WebviewController=newwebview.WebviewController();
uiContext:UIContext=this.getUIContext();
build() {
 Row() {
  Web({src:"",controller:this.controller})
    .onControllerAttached(() =>{
    try{
     // 设置允许可以跨域访问的路径列表
     this.controller.setPathAllowingUniversalAccess([
      this.uiContext.getHostContext()!.resourceDir,
      this.uiContext.getHostContext()!.filesDir+"/example"
      ])
     this.controller.loadUrl("file://"+this.uiContext.getHostContext()!.resourceDir+"/index.html")
     }catch(error) {
     console.error(`ErrorCode:${(errorasBusinessError).code}, Message:${(errorasBusinessError).message}`);
     }
    })
    .javaScriptAccess(true)
    .fileAccess(true)
    .domStorageAccess(true)
  }
 }
}
 



 
 Demo
 
 



 loadFile
// main/resources/resfile/js/script.js
constbody =document.body;
constelement =document.createElement('div');
element.textContent='success';
body.appendChild(element);

3.查看onErrorReceive、onHttpErrorReceive、onSslErrorEvent、onHttpAuthRequest、onClientAuthenticationRequest等错误上报接口是否有被调用。请根据返回的错误码,对照网络协议栈错误列表进行排查。

d15f2b10-7d9c-11f0-a18e-92fbcf53809c.png

复杂的布局与渲染模式导致白屏

若页面使用了复杂布局或渲染模式,需注意其应用场景和约束条件,不当使用可能导致布局混乱或白屏。

Web组件提供了两种渲染模式,能够根据不同的容器大小进行适配,从而满足使用场景中对容器尺寸的需求,详情见Web组件渲染模式。在使用过程中需要注意以下几点:

异步渲染模式下(renderMode:

RenderMode.ASYNC_RENDER),Web组件的宽高不能超过7,680px(物理像素),超过会导致白屏。

同步渲染模式下(renderMode:

RenderMode.SYNC_RENDER),Web组件的宽高不能超过500,000px(物理像素),超过会导致白屏。

Web组件提供了自适应页面布局的能力,详情见 Web组件大小自适应页面内容布局,使用时也需要注意以下约束条件:

配置同步渲染模式:webSetting({renderingMode: WebRenderingMode.SYNCHRONOUS})。

关闭滚动效果:webSetting({overScrollMode: OverScrollMode.NEVER})。

此模式下不支持动态调整组件高度,确保页面高度固定。

避免在FIT_CONTENT模式下启用键盘避让属性RESIZE_CONTENT,以免导致布局失效。

css样式height: vh和Web组件大小自适应页面布局存在计算冲突,请检查height: vh是否是由body节点而内的第一个高度css样式。如以下结构,id为2的dom节点高度将为0,导致白屏。



 子dom
子dom

解决此白屏问题的参考方案如下:

子dom使用具体高度样式撑开父元素。



 
子dom

父元素使用实际高度样式。



 子dom
 子dom

处理H5代码兼容性

兼容性问题处理不当也会导致页面白屏。

特殊协议拦截。

若H5页面调用tel:、mailto:等协议导致白屏,需通过onInterceptRequest拦截并调用系统拨号能力:

.onInterceptRequest((event) =>{
 if(event.request.url.startsWith('tel:')) {
   // 调用系统拨号能力
    call.makeCall({phoneNumber:'123456'});
   return{responseCode:404};// 阻止默认行为
  }
 returnnull; 
})

监控内存与生命周期

内存达到阈值会导致渲染进程被终止,从而引发白屏现象;同样,渲染进程创建失败或非正常销毁也会导致白屏。可从日志中排查原因。检查Web组件是否与WebController正确绑定,或是否因过早释放导致白屏。关注日志中与Render进程相关的信息:是否存在内存泄漏使渲染内存不足。关键字“MEMORY_PRESSURE_LEVEL_CRITICAL”表明内存已达到阈值,此情形下Web可能遭遇黑屏、花屏或闪屏等异常状况,需排查是否存在内存泄漏问题。Render进程是否成功启动或异常退出。

下面列举一些日志中的关键字和对应的情况说明:

d174f4cc-7d9c-11f0-a18e-92fbcf53809c.png

下面说明一下Web组件网络加载过程中的关键日志,正常情况下一个Web组件的加载过程应该包含这些关键节点:

d1908f98-7d9c-11f0-a18e-92fbcf53809c.png

d19f1d74-7d9c-11f0-a18e-92fbcf53809c.png


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Web
    Web
    +关注

    关注

    2

    文章

    1291

    浏览量

    71954
  • 网络
    +关注

    关注

    14

    文章

    7894

    浏览量

    91361
  • 开发者
    +关注

    关注

    1

    文章

    662

    浏览量

    17697

原文标题:Web白屏问题定位与解决指南

文章出处:【微信号:HarmonyOS_Dev,微信公众号:HarmonyOS开发者】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    鸿蒙OpenHarmony:【常见编译问题和解决方法

    常见编译问题和解决方法
    的头像 发表于 05-11 16:09 ?3929次阅读

    屏幕白屏解决方法

    我的屏幕开始可以正常显示,但是在加入一个测方波的频率程序以后在刷新了几次以后就会白屏,请问各位这是什么原因?有什么解决方案?
    发表于 08-06 14:48

    贴片机送料器系统的故障表现和解决方法

    料器,在机器运行时进行这项工作是被严格禁止的,需按下列步骤进行。  ①按下Cycle Stop开关,等待机器停止;  ②拔下或安装送料器;  ③松开Cycle Stop按钮;  ④按下Start按键继续生产。  (2)常见的送料器故障表现和解决方法  如表2所示。  表2
    发表于 09-07 16:33

    使用WebView组件实现应用与Web页面间的通信

    组件为例,从WebView组件构建、Web页面加载、应用与WebView中Web页面间的交互三个方面出发,让您快速了解WebView组件的基本能力及使用
    发表于 08-26 10:39

    web页面与C代码的数据交换方法是什么

    有什么情况可以保证网页内容不被改变呢?web页面与C代码的数据交换方法是什么?
    发表于 02-22 08:04

    HarmonyOS—使用Web组件加载页面

    ??loadUrl()??接口变更当前Web组件的页面。 在下面的示例中展示加载本地页面文件的方法: ● 将资源文件放置在应用的resources/rawfile目录下。**图1 **
    发表于 08-31 17:51

    BIOS错误信息和解决方法

    BIOS错误信息和解决方法 1.CMOS battery failed(CMOS电池失效) 原因:说明CMOS电池的电力已经不
    发表于 03-10 11:49 ?4522次阅读

    关于开关电源的电磁干扰问题研究和解决方法

    关于开关电源的电磁干扰问题研究和解决方法 开关电源由于本身工作特性使得电磁干扰问题相当突出。从开关电源电磁干扰的模
    发表于 06-30 20:22 ?1439次阅读
    关于开关电源的电磁干扰问题研究<b class='flag-5'>和解决方法</b>

    光绘胶卷一些常见的冲洗问题和解决方法(图解法)

    光绘胶卷一些常见的冲洗问题和解决方法(图解法)
    发表于 03-15 10:25 ?1582次阅读

    采用MATLAB对SPWM进行辅助设计与详细分析和解决方法

    采用MATLAB对SPWM进行辅助设计与详细分析和解决方法
    发表于 09-14 14:22 ?18次下载
    采用MATLAB对SPWM进行辅助设计与详细分析<b class='flag-5'>和解决方法</b>

    一文解读MES系统中选型困惑和解决方法

    本文主要介绍了MES系统中选型困惑和解决方法
    发表于 06-26 08:00 ?1次下载

    保护死区的概念和解决方法

    保护死区的概念和解决方法
    的头像 发表于 07-15 11:02 ?2170次阅读
    保护死区的概念<b class='flag-5'>和解决方法</b>

    变频器过热的故障原因和解决方法

    变频器过热的故障原因和解决方法
    的头像 发表于 10-24 10:09 ?8470次阅读

    GSM系统中干扰问题的分类、定位和解决方法

    电子发烧友网站提供《GSM系统中干扰问题的分类、定位和解决方法.pdf》资料免费下载
    发表于 11-17 16:53 ?0次下载
    GSM系统中干扰问题的分类、定位<b class='flag-5'>和解决方法</b>

    HarmonyOS Web页面加载的原理和优化方法

    在移动互联网时代,应用的页面渲染速度对于用户体验至关重要。相对于原生页面Web页面的性能存在多方面的技术挑战。本文以HarmonyOS的ArkWeb组件为基础,介绍了
    的头像 发表于 12-05 15:14 ?1182次阅读
    HarmonyOS <b class='flag-5'>Web</b><b class='flag-5'>页面</b>加载的原理和优化<b class='flag-5'>方法</b>