Web组件如何判断网址是否加载成功

Web组件如何判断网址是否加载成功

HarmonyOS
2024-03-17 17:33:32
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
失望的满天星
  • 方案一:在设备无网络时,网页加载会发生错误,可以触发Web组件的onErrorReceive回调函数。
  • 方案二:在网页加载资源遇到HTTP错误(响应码>=400)时,可以触发Web组件的onHttpErrorReceive回调函数。

开发者可以根据不同的场景在对应的回调函数中进行相应的处理。

onErrorReceive:

// xxx.ets 
import { webview } from '@kit.ArkWeb'; 
 
@Entry 
@Component 
struct WebComponent { 
  controller: webview.WebviewController = new webview.WebviewController(); 
 
  build() { 
    Column() { 
      Web({ src: 'www.baidu.com', controller: this.controller }) 
        .onErrorReceive((event) => { 
          if (event) { 
            console.log('getErrorInfo:' + event.error.getErrorInfo()); 
            console.log('getErrorCode:' + event.error.getErrorCode()); 
            console.log('url:' + event.request.getRequestUrl()); 
            console.log('isMainFrame:' + event.request.isMainFrame()); 
            console.log('isRedirect:' + event.request.isRedirect()); 
            console.log('isRequestGesture:' + event.request.isRequestGesture()); 
            console.log('getRequestHeader_headerKey:' + event.request.getRequestHeader().toString()); 
            let result = event.request.getRequestHeader(); 
            console.log('The request header result size is ' + result.length); 
            for (let i of result) { 
              console.log('The request header key is : ' + i.headerKey + ', value is : ' + i.headerValue); 
            } 
          } 
        }) 
    } 
  } 
}

onHttpErrorReceive:

// xxx.ets 
import { webview } from '@kit.ArkWeb'; 
 
@Entry 
@Component 
struct WebComponent { 
  controller: webview.WebviewController = new webview.WebviewController(); 
 
  build() { 
    Column() { 
      Web({ src: 'www.example.com', controller: this.controller }) 
        .onHttpErrorReceive((event) => { 
          if (event) { 
            console.log('url:' + event.request.getRequestUrl()); 
            console.log('isMainFrame:' + event.request.isMainFrame()); 
            console.log('isRedirect:' + event.request.isRedirect()); 
            console.log('isRequestGesture:' + event.request.isRequestGesture()); 
            console.log('getResponseData:' + event.response.getResponseData()); 
            console.log('getResponseEncoding:' + event.response.getResponseEncoding()); 
            console.log('getResponseMimeType:' + event.response.getResponseMimeType()); 
            console.log('getResponseCode:' + event.response.getResponseCode()); 
            console.log('getReasonMessage:' + event.response.getReasonMessage()); 
            let result = event.request.getRequestHeader(); 
            console.log('The request header result size is ' + result.length); 
            for (let i of result) { 
              console.log('The request header key is : ' + i.headerKey + ' , value is : ' + i.headerValue); 
            } 
            let resph = event.response.getResponseHeader(); 
            console.log('The response header result size is ' + resph.length); 
            for (let i of resph) { 
              console.log('The response header key is : ' + i.headerKey + ' , value is : ' + i.headerValue); 
            } 
          } 
        }) 
    } 
  } 
}
分享
微博
QQ
微信
回复
2024-03-18 21:11:05
相关问题
如何判断Web组件是否全屏
918浏览 • 1回复 待解决
Web如何判断是否发生重定向
479浏览 • 1回复 待解决
如何禁止web组件自动加载图片?
416浏览 • 1回复 待解决
Web组件中的预加载如何实现?
509浏览 • 1回复 待解决
web组件对html文件的加载
441浏览 • 1回复 待解决
TabContent组件是否支持预加载
660浏览 • 1回复 待解决
Web组件是否支持离屏渲染
668浏览 • 0回复 待解决
Web组件是否支持VUE和React
908浏览 • 1回复 待解决
如何确认延迟任务是否申请成功
880浏览 • 1回复 待解决
如何判断HAP是否安装
928浏览 • 1回复 待解决
Web组件是否支持浏览器的localstorage?
508浏览 • 1回复 待解决
如何判断是否为主线程?
415浏览 • 1回复 待解决