鸿蒙ArkTs开发WebView问题总结

1. 加载WebView页面报错"Can not read properties of null (reading 'getltem')"

解决:

在加载webview的controller中加入.domStorageAccess(true)

 build() {
    Column() {
      Row().width('100%').height('50rpx')
      Web({ src: src, controller: this.controller })
        .javaScriptAccess(true)
        .domStorageAccess(true)
    }

  }

官方文档

文档中心

2.如何操作网页中的LocalStorage

解决:

通过操作应用侧runJavaScript()方法调用前端页面的JavaScript相关函数。

本人封装操作LocalStorage 方法

interface JsMethods {
  setStorage(key: string, value: any): Promise<void>;

  getStorage(key: string): Promise<string>
}
/**
 * webview中常用的js操作封装
 */
export class WebJsUtil implements JsMethods {
  private controller: WebviewController;

  constructor(controller: WebviewController) {
    this.controller = controller;
  }

  async setStorage(key: string, value: any): Promise<void> {
    this.controller.runJavaScript("window.localStorage.setItem('" + key + "', '" + value + "')")
  }

  async getStorage(key: string): Promise<string> {
    const res = await this.controller.runJavaScript("window.localStorage.getItem('" + key + "')")
    return res
  }
}

调用:

 build() {
    Column() {
      Row().width('100%').height('50rpx')
      Web({ src: new BaseUrl().APPOINT_LIST, controller: this.controller })
        .javaScriptAccess(true)
        .onPageBegin(async (event) => {
          const access_token = await PreferenceModel.getPreference('access_token')
          const refresh_token = await PreferenceModel.getPreference('refresh_token')
          const webJs = new WebJsUtil(this.controller)
          await webJs.setStorage('userInfo', JSON.stringify(this.userInfo))
          await webJs.setStorage('access_token', access_token)
          await webJs.setStorage('refresh_token', refresh_token)
        })
        .domStorageAccess(true)
    }

  }

注: window.localStorage.setItem('" + key + "', '" + value + "') 必须在 value 外有两个单引号 包含住

3.WebView 页面在windows模拟器无法出现滚动条滚动

解决:

亲测在Mac 的模拟器可以滚动,且真实模拟机也可以出现滚动条下拉,固为windows的模拟器bug,开发者无需理会,如必要可用 上下箭头进行页面上下滚动即可

腾讯X5内核是一款支持多进程、支持硬件加速、支持自定义内核扩展的WebView内核。在Android开发中,使用腾讯X5内核可以提高WebView的性能和稳定性,下面是一些优化和实践总结: 1. 引入腾讯X5内核 引入腾讯X5内核需要在项目中添加相应的依赖库,然后在代码中进行初始化和使用。具体步骤可以参考腾讯官方文档。 2. 启用硬件加速 在使用腾讯X5内核时,可以启用硬件加速来提高WebView的渲染速度。具体可以通过设置WebView的LayerType属性来实现,例如: ``` webView.setLayerType(View.LAYER_TYPE_HARDWARE, null); ``` 3. 使用预加载 预加载可以在用户点击链接之前就开始加载下一页的内容,以提高用户体验和减少页面加载时间。腾讯X5内核提供了预加载功能,可以通过设置WebView的预加载模式来实现,例如: ``` webView.getX5WebViewExtension().setPageCacheCapacity(5); // 设置最大缓存页面数为5 webView.getX5WebViewExtension().setPreload(true); // 开启预加载模式 ``` 4. 优化JSBridge通信 JSBridge是一种用于WebView和Native代码之间通信的技术,但是在使用过程中容易出现性能问题。为了优化JSBridge通信,可以使用腾讯X5内核提供的基于V8引擎的JSBridge,它可以提高通信效率和稳定性。 5. 避免WebView内存泄漏 在使用WebView时,需要注意避免内存泄漏问题。具体可以通过以下方式来避免: - 及时释放WebView对象 - 使用静态内部类或弱引用来持有WebView对象 - 在Activity的onDestroy()方法中调用WebView的destroy()方法 总之,腾讯X5内核是一款非常强大的WebView内核,可以帮助我们优化WebView的性能和稳定性。在使用中,需要注意以上几点优化和实践。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值