uniapp手机APP webview使用echarts显示问题(腾讯X5内核)

一、问题描述

webview页面中引用了一些基于echarts封装的js文件,用于在手机上展示仪表盘

在iQOO8 pro上显示并无问题,而在vivo x21A上显示有问题,如下图所示

vivo x21A

iQOO8 pro

二、解决过程

先说结论,出现这个问题是因为echarts和手机浏览器内核不兼容,webview组件默认使用的是手机系统自带浏览器内核,将app使用的内核更换为腾讯X5内核并重启手机即可解决问题

首先,我尝试通过下载chrome浏览器和QQ浏览器来更新手机的浏览器内核,但是都没有生效,也尝试过手动更新webview内核,但是因为方法过于繁琐就放弃了。

后来发现uniapp可以将webview使用的内核修改为腾讯X5内核,只需在manifest的app模块配置中,勾选Android X5 Webview(腾讯TBS)即可,具体方法注意事项参考uni-app官网

勾选之后一定要重新制作自定义基座或者云打包,否则不会生效。

最后,将APP安装到手机之后一定要重启手机

三、与内核相关的一些尝试

微信,最开始尝试在微信中打开X5内核调试专用页、debugmm.qq.com/?forcex5=true和X5内核调试专用页等页面查看微信使用的X5内核版本,但是由于新版本的微信已经不再使用X5内核所以从微信得到的结论只是需要下载X5内核(如果有朋友知道旧版本的微信能不能查看X5内核版本可以留个评论)。

系统设置,在开发者选项中可以查看手机使用的webview内核,但是即便App使用了X5内核,这里也只会显示Android System Webview及其版本。

uniapp,从uni-app官网中得知,可以在uniapp中打印这段代码plus.navigator.getUserAgent(),如果在打印的文字中出现了MQQBrowser关键字,则代表当前的app使用了X5内核。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
腾讯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的性能和稳定性。在使用中,需要注意以上几点优化和实践。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值