WebView性能、体验分析与优化

378 篇文章 71 订阅
订阅专栏

在App开发中,内嵌WebView始终占有着一席之地。它能以较低的成本实现Android、iOS和Web的复用,也可以冠冕堂皇的突破苹果对热更新的封锁。

然而便利性的同时,WebView的性能体验却备受质疑,导致很多客户端中需要动态更新等页面时不得不采用其他方案。

以发展的眼光来看,功能的动态加载以及三端的融合将会是大趋势。那么如何克服WebView固有的问题呢?我们将从性能、内存消耗、体验、安全几个维度,来系统的分析客户端默认WebView的问题,以及对应的优化方案。

对于WebView的性能,给人最直观的莫过于:打开速度比native慢。

是的,当我们打开一个WebView页面,页面往往会慢吞吞的loading很久,若干秒后才出现你所需要看到的页面。

这是为什么呢?

对于一个普通用户来讲,打开一个WebView通常会经历以下几个阶段:

  1. 交互无反馈
  2. 到达新的页面,页面白屏
  3. 页面基本框架出现,但是没有数据;页面处于loading状态
  4. 出现所需的数据

如果从程序上观察,WebView启动过程大概分为以下几个阶段:

WebView启动时间

如何缩短这些过程的时间,就成了优化WebView性能的关键。

接下来我们逐一分析各个阶段的耗时情况,以及需要注意的优化点。

WebView初始化

当App首次打开时,默认是并不初始化浏览器内核的;只有当创建WebView实例的时候,才会创建WebView的基础框架。

所以与浏览器不同,App中打开WebView的第一步并不是建立连接,而是启动浏览器内核

我们来分析一下这段耗时到底需要多久。

分析

针对WebView的初始化时间,我们可以定义两个指标:

  • 首次初始化时间:客户端冷启动后,第一次打开WebView,从开始创建WebView到开始建立网络连接之间的时间。
  • 二次初始化时间:在打开过WebView后,退出WebView,再重新打开WebView,从开始创建WebView到开始建立网络连接之间的时间。

测试数据:

测试系统1: iOS模拟器,Titans 10.0.7

测试系统2: OPPO R829T Android 4.2.2

测试方式:测试10次取平均值

测试App:美团外卖

单位:ms

首次初始化时间二次初始化时间
iOS(UIWebView)306.5676.43
iOS(WKWebView)763.26457.25
Android192.79 *142.53

*Android外卖客户端启动后会在后台开启WebView进程,故并不是完全新建WebView时间。

这意味着什么呢?

作为前端工程师,统计了无数次的页面打开时间,都是以网络连接开始作为起点的。

很遗憾的通知您:WebView中用户体验到的打开时间需要再增加70~700ms。

于是我们找到了“为什么WebView总是很慢”的原因之一:

  • 在浏览器中,我们输入地址时(甚至在之前),浏览器就可以开始加载页面。
  • 而在客户端中,客户端需要先花费时间初始化WebView完成后,才开始加载。

而这段时间,由于WebView还不存在,所有后续的过程是完全阻塞的。可以这样形容WebView初始化过程:

WebView启动过程

那么有哪些解决办法呢?

怎么优化

由于这段过程发生在native的代码中,单纯靠前端代码是无法优化的;大部分的方案都是前端和客户端协作完成,以下是几个业界采用过的方案。

全局WebView

方法:

  • 在客户端刚启动时,就初始化一个全局的WebView待用,并隐藏;
  • 当用户访问了WebView时,直接使用这个WebView加载对应网页,并展示。

这种方法可以比较有效的减少WebView在App中的首次打开时间。当用户访问页面时,不需要初始化WebView的时间。

当然这也带来了一些问题,包括:

  • 额外的内存消耗。
  • 页面间跳转需要清空上一个页面的痕迹,更容易内存泄露。

【参考东软专利 - 加载网页的方法及装置 CN106250434A】

客户端代理数据请求

方法:

  • 在客户端初始化WebView的同时,直接由native开始网络请求数据;
  • 当页面初始化完成后,向native获取其代理请求的数据。

此方法虽然不能减小WebView初始化时间,但数据请求和WebView初始化可以并行进行,总体的页面加载时间就缩短了;缩短总体的页面加载时间:

【参考腾讯分享: 70%以上业务由H5开发,手机QQ Hybrid 的架构如何优化演进?】

还有其他各种优化的方式,不再一一列举,总结起来都是围绕两点:

  1. 在使用前预先初始化好WebView,从而减小耗时。
  2. 在初始化的同时,通过Native来完成一些网络请求等过程,使得WebView初始化不是完全的阻塞后续过程。

建立连接/服务器处理

在页面请求的数据返回之前,主要有以下过程耗费时间。

  • DNS
  • connection
  • 服务器处理

分析

以下为美团中活动页面的链接时间统计:

统计: 美团的活动页面

内容值: n%分位值(ms)

DNSconnection获取首字节
50%1.371172
90%60360541

优化

这些时间都是发生在网页加载之前,但这并不意味着无法优化,有以下几种方法。

DNS采用和客户端API相同的域名

DNS会在系统级别进行缓存,对于WebView的地址,如果使用的域名与native的API相同,则可以直接使用缓存的DNS而不用再发起请求图片。

以美团为例,美团的客户端请求域名主要位于api.meituan.com,然而内嵌的WebView主要位于 i.meituan.com。

当我们初次打开App时:

  • 客户端首次打开都会请求api.meituan.com,其DNS将会被系统缓存。
  • 然而当打开WebView的时候,由于请求了不同的域名,需要重新获取i.meituan.com的IP。

根据上面的统计,至少10%的用户打开WebView时耗费了60ms在DNS上面,如果WebView的域名与App的API域名统一,则可以让WebView的DNS时间全部达到1.3ms的量级

静态资源同理,最好与客户端的资源域名保持一致。

同步渲染采用chunk编码

同步渲染时如果后端请求时间过长,可以考虑采用chunk编码,将数据放在最后,并优先将静态内容flush。对于传统的后端渲染页面,往往都是使用的【浏览器】–> 【Web API】 –> 【业务 API】的加载模式,其中后端时间就指的是Web API的处理时间了。在这里Web API一般有两个作用:

  1. 确定静态资源的版本。
  2. 根据用户的请求,去业务API获取数据。

而一般确定静态资源的版本往往是直接读取代码版本,基本无耗时;而主要的后端时间都花费在了业务API请求上面。

那么怎么优化利用这段时间呢?

在HTTP协议中,我们可以在header中设置 transfer-encoding:chunked 使得页面可以分块输出。如果合理设计页面,让head部分都是确定的静态资源版本相关内容,而body部分是业务数据相关内容,那么我们可以在用户请求的时候,首先将Web API可以确定的部分先输出给浏览器,然后等API完全获取后,再将API数据传输给浏览器。

下图可以直观的看出分chunk输出和一起输出的区别:

分chunk加载

  • 如果采用普通方式输出页面,则页面会在服务器请求完所有API并处理完成后开始传输。浏览器要在后端所有API都加载完成后才能开始解析。
  • 如果采用chunk-encoding: chunked,并优先将页面的静态部分输出;然后处理API请求,并最终返回页面,可以让后端的API请求和前端的资源加载同时进行。
  • 两者的总共后端时间并没有区别,但是可以提升首字节速度,从而让前端加载资源和后端加载API不互相阻塞。

页面框架渲染

页面在解析到足够多的节点,且所有CSS都加载完成后进行首屏渲染。在此之前,页面保持白屏;在页面完全下载并解析完成之前,页面处于不完整展示状态。

分析

我们以一个美团的活动页面作为样例:

测试页面: http://i.meituan.com/firework/meituanxianshifengqiang

在Mac上面,模拟4G情况

页面样式:

页面

测试得到的时间耗费如下:

表1

阶段时间大小备注
DOM下载58ms29.5 KB4G网络
DOM解析12.5ms198 KB根据估算,在手机上慢2~5倍不等
CSS请求+下载58ms11.7 KB4G网络(包含链接时间,CDN)
CSS解析2.89ms54.1 KB根据估算,在手机上慢2~5倍不等
渲染23ms1361节点根据估算,在手机上慢2~5倍不等
绘制4.1ms根据估算,在手机上慢2~5倍不等
合成0.23msGPU处理

同时,对HTML的加载时间进行分析,可以得到如下时间点。

表2

指标时间计算方法
HTML加载完成时间218performance.timing.responseEnd - performance.timing.fetchStart
HTML解析完成时间330performance.timing.domInteractive - performance.timing.fetchStart

这意味着什么呢?

对于表1

可以看到,随着在网络优良的情况下,Dom的解析所占耗时比例还是不算低的,对于低端机器更甚。Layout时间也是首屏前耗时的大头,据猜测这与页面使用了rem作为单位有关(待进一步分析)。

对于表2,我们可以发现一个问题

一般来说HTML在开始接收到返回数据的时候就开始解析HTML并构建DOM树。如果没有JS(JavaScript)阻塞的话一般会相继完成。然而,在这里时间相差了90ms……也就是说,解析被阻塞了。

进一步分析可以发现,页面的header部分有这样的代码:

.....
<link href="//ms0.meituan.net/css/eve.9d9eee71.css" rel="stylesheet" onload="MT.pageData.eveTime=Date.now()"/>
<script>
window.fk = function (callback) {
require(['util/native/risk.js'], function (risk) {
    risk.getFk(callback);
});
}
</script>
</head>
....

通常情况下,上面代码的link部分和script部分如果单独出现,都不会阻塞页面的解析:

  • CSS不会阻止页面继续向下继续。
  • 内联的JS很快执行完成,然后继续解析文档。

然而,当这两部分同时出现的时候,问题就来了。

  • CSS加载阻塞了下面的一段内联JS的执行,而被阻塞的内联JS则阻塞了HTML的解析。

通常情况下,CSS不会阻塞HTML的解析,但如果CSS后面有JS,则会阻塞JS的执行直到CSS加载完成(即便JS是内联的脚本),从而间接阻塞HTML的解析。

优化

在页面框架加载这一部分,能够优化的点参照 雅虎14条就够了;但注意不要犯错,一个小小的内联JS放错位置也会让性能下降很多。

  1. CSS的加载会在HTML解析到CSS的标签时开始,所以CSS的标签要尽量靠前。
  2. 但是,CSS链接下面不能有任何的JS标签(包括很简单的内联JS),否则会阻塞HTML的解析。
  3. 如果必须要在头部增加内联脚本,一定要放在CSS标签之前。

CSS带来的阻塞解析

JS加载

对于大型的网站来说,在此我们先提出几个问题:

  • 将全部JS代码打成一个包,造成首次执行代码过大怎么办?
  • 将JS以细粒度打包,造成请求过多怎么办?
  • 将JS按 “基础库” + “页面代码” 分别打包,要怎么界定什么是基础代码,什么是页面代码;不同页面用的基础代码不一致怎么办?
  • 单一文件的少量代码改的是否会导致缓存失效?
  • 代码模块间有动态依赖,怎样合并请求。

关于这些问题的解决方案数量可能会比问题还多,而它们也各有优劣。

具体分析太过复杂,鉴于篇幅原因在这里不做具体分析了。您可以期待我们的后续计划:BPM(浏览器包管理)。

JS解析、编译、执行

在PC互联网时代,人们似乎都快忘记了JS的解析和执行还需要消耗时间。确实,在几年前网速还在用kb衡量的时代里,JS的解析时间在整个页面的打开时间里只能算是九牛一毛。

然而,随着网速越来越快,而CPU的速度反而没有提升(从PC到手机),JS的时间开销就成为问题了。那么JS的编译和解析,在当今的页面上要消耗多少时间呢?

分析

我们用以下方式来检验JS代码的解析/编译和执行时间:

<script>
    window.t1 = performance.now()
</script>
<script>
    window.test = function () {
        // test code
    }
</script>
<script>
    window.t2 = performance.now()
    test();
    window.t3 = performance.now();
     
    alert("编译耗时:" + (t2 - t1));
    alert("执行耗时:" + (t3 - t2));
</script>

将测试代码放入 【test code】 位置,然后在手机中执行;

  • 在t1~t2期间,JS代码仅仅声明了一个函数,主要时间会集中在解析和编译过程;

  • 在t2~t3时间段内,执行test时时间主要为代码的执行时间

在首次启动客户端后,打开WebView的测试页面,我们可以得到如下的结果:

测试系统: iPhone6 iOS 10.2.1

测试系统: OPPO R829T Android 4.2.2

内容值: 编译时间(ms)/执行时间(ms)

系统Zepto.jsVue.jsReact.js + ReactDOM.js
iOS5.2 / 812.8 / 16.113.7 / 43.3
Android13 / 4043 / 12726 / 353

当保持客户端进行不关闭情况下,关闭WebView并重新访问测试页面,再次测试得到如下结果:

系统Zepto.jsVue.jsReact.js + ReactDom.js
iOS0.9 / 1.95 / 7.43.5 / 23
Android5 / 917 / 1225 / 60

执行时间指的是框架代码加载的页面的初始化时间,没有任何业务的调用。

这意味着什么

经过测试可以得出以下结论: * 偏重的框架,例如React,仅仅初始化的时间就会达到50ms ~ 350ms,这在对性能敏感的业务中时比较不利的。 * 在App的启动周期内,统一域名下的代码会被缓存编辑和初始化结果,重复调用性能较好。

所以,在移动浏览器上,JS的解析和执行时间并不是不可忽略的。

在低端安卓机上,(框架的初始化+异步数据请求+业务代码执行)会远高于几KB网络请求时间;高性能的Web网站需要仔细斟酌前端渲染带来的性能问题。

优化

  • 高性能要求页面还是需要后端渲染。
  • React还是太重了,面向用户写系统需要谨慎考虑。
  • JS代码的编译和执行会有缓存,同App中网页尽量统一框架。

WebView性能优化总结

一个加载网页的过程中,native、网络、后端处理、CPU都会参与,各自都有必要的工作和依赖关系;让他们相互并行处理而不是相互阻塞才可以让网页加载更快:

  • WebView初始化慢,可以在初始化同时先请求数据,让后端和网络不要闲着。
  • 后端处理慢,可以让服务器分trunk输出,在后端计算的同时前端也加载网络静态资源。
  • 脚本执行慢,就让脚本在最后运行,不阻塞页面解析。
  • 同时,合理的预加载、预缓存可以让加载速度的瓶颈更小。
  • WebView初始化慢,就随时初始化好一个WebView待用。
  • DNS和链接慢,想办法复用客户端使用的域名和链接。
  • 脚本执行慢,可以把框架代码拆分出来,在请求页面之前就执行好。

分析

为了测试WebView会消耗多少内存,我们设计了如下的测试方案:

  1. 客户端启动后,记录消耗的内存。
  2. 打开空页面,记录内存的上涨。
  3. 退出。
  4. 打开空页面,记录内存上涨。
  5. 退出。
  6. 打开加载了代码的页面,记录内存的额外增加。

得到如下测试结果:

测试系统: iOS模拟器,Titans 10.0.7

测试系统: OPPO R829T Android 4.2.2

测试方式:测试10次取平均值

首次打开增加内存二次打开增加内存加载KNB+VUE+灵犀
iOS UIWebView31.1M5.52M2M
iOS WKWebView1.95M1.6M2M
Android32.2M6.62M1.7M

WKWebView的内存消耗相比其他低了一个数量级,在此方面相当占优。

UIWebView和Android的WebView在首次初始化时都要消耗大量内存,之后每次新建WebView会额外增加一些。

UIWebView的内存占用不会在关闭WebView时主动回收,每次新开WebView都会消耗额外内存。

相比于性能,对于内存的优化可以做的还是比较有限的。

  • WKWebView的内存占用优势比较大(代价是初始化比较慢)。
  • 页面内代码消耗的内存相比与WebView系统的内存消耗相比可以说是很低。

除了打开的速度,WebView通常体验也没有native的实现更好,我们可以找到以下几个例子:

长按选择

在WebView中,长按文字会使得WebView默认开始选择文字;长按链接会弹出提示是否在新页面打开。

解决方法:可以通过给body增加CSS来禁止这些默认规则。

点击延迟

在WebView中,click通常会有大约300ms的延迟(同时包括链接的点击,表单的提交,控件的交互等任何用户点击行为)。

唯一的例外是设置的meta:viewpoint为禁止缩放的Chrome(然而并不是Android默认的浏览器)。

解决方法:使用fastclick一般可以解决这个问题。

页面滑动期间不渲染/执行

在很多需求中会有一些吸顶的元素,例如导航条,购买按钮等;当页面滚动超出元素高度后,元素吸附在屏幕顶部。

这个功能在PC和native中都能够实现,然而在WebView中却成了难题:

 在页面滚动期间,Scroll Event不触发

不仅如此,WebView在滚动期间还有各种限定:

  • setTimeout和setInterval不触发。
  • GIF动画不播放。
  • 很多回调会延迟到页面停止滚动之后。
  • background-position: fixed不支持。
  • 这些限制让WebView在滚动期间很难有较好的体验。

这些限制大部分是不可突破的,但至少对于吸顶功能还是可以做一些支持:

解决方法:

  • 在iOS上,使用position: sticky可以做到元素吸顶。
  • 在Android上,监听touchmove事件可以在滑动期间做元素的position切换(惯性运动期间就无效了)。

crash

通常WebView并不能直接接触到底层的API,因此比较稳定;但仍然有使用不当造成整个App崩溃的情况。

目前发现的案例包括:

  • 使用过大的图片(2M)
  • 不正常使用WebGL

WebView被运营商劫持、注入问题

由于WebView加载的页面代码是从服务器动态获取的,这些代码将会很容易被中间环节所窃取或者修改,其中最主要的问题出自地方运营商(浙江尤其明显)和一些WiFi。

我们监测到的问题包括:

  • 无视通信规则强制缓存页面。
  • header被篡改。
  • 页面被注入广告。
  • 页面被重定向。
  • 页面被重定向并重新iframe到新页面,框架嵌入广告。
  • HTTPS请求被拦截。
  • DNS劫持。

这些问题轻则影响用户体验,重则泄露数据,或影响公司信誉。

针对页面注入的行为,有一些解决方案:

使用CSP(Content Security Policy)

CSP可以有效的拦截页面中的非白名单资源,而且兼容性较好。在美团移动版的使用中,能够阻止大部分的页面内容注入。

但在使用中还是存在以下问题:

  • 由于业务的需要,通常inline脚本还是在白名单中,会导致完全依赖内联的页面代码注入可以通过检测。
  • 如果注入的内容是纯HTML+CSS的内容,则CSP无能为力。
  • 无法解决页面被劫持的问题。
  • 会带来额外的一些维护成本。

总体来说CSP是一个行之有效的防注入方案,但是如果对于安全要求更高的网站,这些还不够。

HTTPS

HTTPS可以防止页面被劫持或者注入,然而其副作用也是明显的,网络传输的性能和成功率都会下降,而且HTTPS的页面会要求页面内所有引用的资源也是HTTPS的,对于大型网站其迁移成本并不算低。

HTTPS的一个问题在于:一旦底层想要篡改或者劫持,会导致整个链接失效,页面无法展示。这会带来一个问题:本来页面只是会被注入广告,而且广告会被CSP拦截,而采用了HTTPS后,整个网页由于受到劫持完全无法展示。

对于安全要求不高的静态页面,就需要权衡HTTPS带来的利与弊了。

App使用Socket代理请求

如果HTTP请求容易被拦截,那么让App将其转换为一个Socket请求,并代理WebView的访问也是一个办法。

通常不法运营商或者WiFi都只能拦截HTTP(S)请求,对于自定义的包内容则无法拦截,因此可以基本解决注入和劫持的问题。

Socket代理请求也存在问题。

  • 首先,使用客户端代理的页面HTML请求将丧失边下载边解析的能力;根据前面所述,浏览器在HTML收到部分内容后就立刻开始解析,并加载解析出来的外链、图片等,执行内联的脚本……而目前WebView对外并没有暴露这种流式的HTML接口,只能由客户端完全下载好HTML后,注入到WebView中。因此其性能将会受到影响。

  • 其次,其技术问题也是较多的,例如对跳转的处理,对缓存的处理,对CDN的处理等等……稍不留神就会埋下若干大坑。

此外还有一些其他的办法,例如页面的MD5检测,页面静态页打包下载等等方式,具体如何选择还要根据具体的场景抉择。

客户端内打开第三方WebView

一般来说,客户端内的WebView都是可以通过客户端的某个schema打开的,而要打开页面的URL很多都并不写在客户端内,而是可以由URL中的参数传递过去的。

那么,一旦此URL可以通过外界输入自定义,那么就有可能在客户端内部打开一个外部的网页。

例:作案过程

  • 某个App有个WebView,打开的schema为 appxx://web?url={weburl}。
  • App中有个扫码的功能,可以扫描某个二维码并打开对应的schema链接。
  • 某个坏人制作了一个二维码并张贴到街上,内容符合 : appxx://web?url={some_hack_weburl}。
  • 用户扫码打开了some_hack_weburl。
  • 如果some_hack_weburl是一个高仿的登录页面,那么用户将会很可能将用户名密码提交到其他网站。

解决方法:在内嵌的WebView中应该限制允许打开的WebView的域名,并设置运行访问的白名单。或者当用户打开外部链接前给用户强烈而明显的提示。

在一个客户端内,native目前主要功能是提供高效而基础的功能;内部的WebView则添加一些性能体验要求不高但动态化要求高的能力。

提高客户端的动态能力,或者提高WebView的性能,都是提升App功能覆盖的方式。

而目前的各种框架,ReactNative、Week包括微信小程序,都是这个趋势的尝试。

随着技术的发展,WebView的性能、体验和安全问题也将会逐渐的改善,在App中占有越来越多比重的同时,也将会为App开拓新的能力,为用户带来更优质的体验。

dest

小程序webview跳转小程序页面_微信小程序性能优化方案——让你的小程序如此丝滑...
weixin_39654903的博客
11-23 1148
作者:雾豹链接:juejin.im/post/5bdbc28e51882516eb55dd1d今天给大家推荐是小程序中的可优化的技巧,记得一定要看完,和其中的细节部分微信小程序如果想要优化性能,有关键性的两点:提高加载性能提高渲染性能接下来分别来介绍一下:提高加载性能首先,问一个问题,当用户点击小程序后发生了什么?上图中的三个状态,我们经常遇到,它们分别对应小程序的下面三个状态:有三个...
前端不哭!webview 性能优化,应该关注哪些指标?(好文收藏)
奎特尔星球
11-10 1097
前一段时间,ELab团队对 webview 做了一期性能优化,在优化过程中,我们追求的是页面要足够「快」「稳」。那怎么定量地衡量这个「快」「稳」呢?性能指标帮助我们从数据化角度了解页面性能...
WebView常见问题及解决方案
最新发布
Unity打怪升级
08-19 381
WebView是移动应用开发中用于嵌入网页内容的重要组件。虽然它极大地丰富了应用的功能,但在实际开发过程中,开发者可能会遇到各种问题。本文将列举一些常见的WebView问题,并提供相应的解决方案。
Uniapp】Uniapp 实现内嵌 H5(webview)提高性能
Tellsea
08-03 4858
文章目录Uniapp 实现内嵌 H51、如何内嵌H52、内嵌存在问题3、调用js4、无法使用缓存微信公众号 Uniapp 实现内嵌 H5 这里我把参考网友的笔记,把使用到的问题都整理了一下,直接照葫芦画瓢就OK了,有时间我再整理自己的笔记 1、如何内嵌H5 android入门-android内嵌H5页面 2、内嵌存在问题 Android内嵌H5(1) 3、调用js Android内嵌H5(2) 4、无法使用缓存 android webview 中缓存无效 微信公众号 ...
了解Android WebView
Working...
10-13 740
最近公司的项目在做H5测试,自己只是写业务逻辑的android小白,听着大家在说什么webview、webkit....,云里雾里。所以就抽出下班后的一点时间开学习和了解一下相关的概念和知识点,然后总结一下记录下来。 1、为什么android app 可以显示web页面? 作为Android开发者,我们都知道在手机中内置了一款高性能 webkit 内核浏览器,在 SDK 中封装为一个叫做 We
uni-app: 从运行原理上面解决性能优化问题
u010227042的博客
08-27 2314
前言 Uni-App,从了解到开发,相信大家都会觉得Uni-App性能不好,其实也这是非原生的弊病。React Native、Flutter等,非原生框架,性能上都会或多或少的折损。但各个框架,都会做出性能提升建议,所以开发者在开发前,多了解一下,后面维护升级等就会更方便一点,否则项目越来越大,后续开发就会越来越难。 uni-app: 如何高效开发uni app?" /> 现在我们就从uni-app运行原理上,了解一下,在哪些方面存在性能折损问题? 运行原理 逻辑层和视图层分离,非H5端
Android WebView 优化之路
09-02
4. **WebView配置优化**:合理的WebView设置能显著提升性能和用户体验。例如: - 启用JavaScript:`settings.setJavaScriptEnabled(true);` - 设置缓存路径:`settings.setAppCachePath(cacheDirPath);` - 允许...
快手 APM 平台建设与性能优化.pdf
09-26
快手 APM 平台建设与性能优化 APM(Application Performance Management)是指对应用程序性能的监控和优化,以提高用户体验和满意度。在快手平台中,APM 的重要性不言而喻。本文将从快手 APM 平台建设的角度,探讨...
webview分析
06-04
"分析.txt"可能包含了对WebView性能、安全性或特定问题的详细分析分析内容可能涉及WebView的加载速度优化(如启用硬件加速、减少HTTP请求)、安全问题(如防止XSS攻击、点击劫持)以及如何处理JavaScript与原生...
Webview的加载流程与性能优化
了解Webview的加载过程是优化Webview性能的基础。Webview加载过程可以概括为以下几个步骤: - 步骤 1:创建Webview实例:通过编程方式,在应用程序中创建Webview实例。 - 步骤 2:设置Webview属性:对Webview进行...
WPF与WebView2双向通信 WPF发送数据到WebView2显示的网页当中 WPF制作的浏览器与网页双向通信 WPF与网页
12-27
性能优化: 相比于传统的嵌入式浏览器控件,WebView2基于现代的Chromium内核,提供了更好的性能和兼容性。 扩展性: 通过JavaScript接口和消息传递机制,可以轻松地扩展和定制WebView2的功能,满足特定的应用需求。...
3D WebView for Windows and macOS Web Browser 3.11.unitypackage
06-29
3D WebView for Windows and macOS (Web Browser) V
Unity插件】UniWebView:在 Unity 中实现高效网页集成
Unity打怪升级
07-30 744
Unity 开发中,有时需要在应用内嵌入网页以提供丰富的内容和功能。UniWebView 就是一个强大的工具,为我们在 Unity 项目中集成网页提供了便捷且高效的解决方案。
unity webgl启动时间优化
u013172864的博客
06-19 1万+
接触过unity发布成webgl的都应该被其加载的启动时间恶心过吧,真的很,对用户体验很差我的解决办法是1.Resources文件夹里东西越多越,能弄成ab包就尽量弄成,图片资源预知体什么的最好别放这文件夹下2.建议使用brotli压缩方式3.那就是服务器做缓存机制,了解webgl文件包的应该度知道其文件格式,主要数据在build文件下我测试了很多次加载过程,发现大部分时间都是在下载和解压.u...
Unity UniWebView内置浏览器插件
Yxwx的博客
10-22 1202
这是一个可以在APP内打开网页的插件,功能比较完善,这里记录一下使用 使用方法: 插件使用还是比较容易上手的,导入插件后,新建一个空物体,挂上UniWebView组件 组件简单清晰,每个部分的功能和名字相同,这里就不赘述了 我自己在使用中发现,当你在打开了网页之后,使用返回键关闭时脚本会自动销毁当前挂载UniWebView的对象,所以没办法在一个对象上重复打开其它网页,需要每次使用的时候生成一个挂载UniWebView组件的对象,然后调用对应的方法来启动网页 启动方法: UniWebView webVie
UnityUniWebView的使用
热门推荐
weixin_42186644的博客
03-15 1万+
文章目录一、介绍二、使用三、坑 一、介绍 背景: 需要直接在游戏内展示一个webview视窗 UniWebView(版本3.0+) UniWebView 是一个 Unity 3D 插件,用于将 Web 视图组件添加到 iOS 和 Android 上的 Unity 3D 手机游戏。它在 C# 中提供了一组抽象、跨平台和高级 API。使用 UniWebView,您可以在不了解原生开发的情况下将一些行为(例如浏览器)放入您的游戏中。 当您需要显示公告或通知、为玩家排名添加排行榜或向您的用户显示任何交互式网页时
优化Unity UI,告别卡顿只需这几招!
qq_42120268的博客
06-20 1359
优化Unity的UI性能和内存使用是一个复杂但非常重要的任务。通过合理使用Canvas、优化资源、采用合批技术和异步加载等策略,可以显著提升UI的性能和用户体验。如果您在开发过程中遇到任何问题或有进一步的优化需求,欢迎随时交流讨论。
解决uniapp的web-view打开网页在老手机上出现白屏的问题
卡农的魔笛
06-15 6136
版本 VUE3 + typescript + vite。unexpected token ?
uniapp 微信小程序webview 踩坑
Raccon_的博客
08-31 5672
微信小程序的存在许多功能上的限制和约束,有些情况不得不去使用webview进行开发实现需求,比如原生无法满足(例如某团队维护SDK 只提供了WEB端jsSDK,且不维护小程序SDK)H5可以同时适用多端(适用范围更广)H5可以弥补小程序部分欠缺微信生态有部分限制(包大小,设计规范等)由于最近做的需求小程序不支持播放带有透明通道的视频,所以转到了webview这里总结下完整的开发流程和现有的各种解决方案: 开发阶段需要将不校验合法域名勾选上。
Android WebView性能优化与JavaScript交互探讨
"Android Webview的使用与性能优化" 在Android开发中,WebView是一个重要的组件,它允许我们在应用程序内部展示网页内容。WebView基于WebKit内核,其表现与Firefox浏览器相当,因此开发者通常会在Firefox中预览并...
写文章

热门文章

  • 支付系统-对账系统 19198
  • java程序员的必用的9款开发工具 11710
  • 架构师的主要职责是什么? 11456
  • 【深度揭秘】百度、阿里、腾讯内部岗位级别和薪资结构,附带求职建议! 10333
  • 支付系统-概念与架构 10220

分类专栏

  • 美团技术 378篇
  • CTO 2篇
  • 架构设计 11篇
  • 分布式
  • 求职跳槽
  • 负载均衡 1篇
  • 分布式系统 4篇
  • 消息中间件 7篇
  • 职业规划 4篇
  • 分布式缓存 1篇
  • 数据库设计
  • 分布式文件
  • 数据库 2篇
  • 求职简历 3篇
  • Kafka 1篇
  • Spring-Boot 79篇
  • 网赚技术 1篇
  • Spring-Cloud 112篇
  • 架构师 18篇
  • Java多线程 16篇
  • Java学习路线 1篇
  • 面试题 26篇
  • 阿里Java面试题 21篇
  • Redis 10篇
  • Java面试题及答案 11篇
  • Java数据结构与算法 2篇
  • 面试经验 7篇
  • 求职 4篇
  • bat薪资岗位 1篇
  • 阿里P7要求 1篇
  • 学习资料 4篇
  • 技术总监 1篇
  • 产品技术 3篇
  • RPC 5篇
  • JVM 7篇
  • Java 7篇
  • 开发书籍 5篇
  • Netty 1篇
  • Java设计模式 1篇
  • Dubbo 2篇
  • MySQL 6篇
  • Docker 2篇
  • Java集合 1篇
  • 架构师职责 1篇
  • SpringCloud 1篇
  • Java NIO 1篇
  • 中间件 2篇
  • Java基础 1篇
  • Java进阶 12篇
  • 性能优化 8篇
  • 架构技能 16篇
  • 微服务 11篇
  • 支付体系 6篇
  • DevOps 1篇

最新评论

  • java程序员学习路线以及我的学习经验

    飞羽疾驰: 可以的,我学的另一个Java路线和资料,5个月后拿了多个满意Offer:https://knife.blog.csdn.net/article/details/132629361

  • 支付系统-对账系统

    lliiqiang: 支付系统数据有是否成功或者取消和是否需要对账状态,本地从第三方获得唯一标志产生数据是成功并且需要对账,然后和第三方对账,第三方产生成功数据,本地数据为已经对账,如果失败就取消本地数据,外界推送数据本地是未成功数据,直到数据成功。定时对账需要对账的数据,不得使用未成功的数据或者注销含有未成功或者需要对账的数据的账号。

  • 美团酒店直连产品数据一致性演进

    2301_81232141: 您好,想要做API接口对接,所以怎么取得您的联系?

  • 最强京东Java面试题(共现场4面)

    zhouhui001: 现在一个小厂都比这个问的难了

  • 支付系统-会计核心

    idogirl: 不对吧,现在网联已将所有银行收敛到它那儿,结算款是它最后总体轧差后结算给备付金,只需要记一个网联的渠道款就可以。

最新文章

  • Spring Boot中使用Swagger2构建强大的RESTful API文档
  • Spring boot中使用log4j记录日志
  • Spring Boot中使用RabbitMQ
2020年790篇
2019年26篇

目录

目录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值

玻璃钢生产厂家内蒙古人物玻璃钢雕塑价格江苏常见商场美陈生产厂家四川通道商场美陈批发枝江玻璃钢园林雕塑东莞led发光玻璃钢雕塑工艺景观玻璃钢雕塑生产厂家定做玻璃钢鹿雕塑价格湖州玻璃钢雕塑批发泉州玻璃钢花盆厂生产厂家永州商场美陈花器河北花钵玻璃钢雕塑报价玻璃钢购物人雕塑上海大型商场美陈哪里有西安哪里能买到玻璃钢雕塑青海园林玻璃钢雕塑制作广元人物玻璃钢雕塑公司温州玻璃钢雕塑摆件市场商场外墙灯光美陈装置玻璃钢雕塑定做厂家玻璃钢雕塑行业未来发展欧式玻璃钢雕塑厂家玉溪市玻璃钢雕塑设计报价玻璃钢雕塑定制厂家推荐宁夏玻璃钢景观雕塑定制玻璃钢动物雕塑图片大全梧州玻璃钢雕塑厂家直销玻璃钢雕塑保质仿真人物玻璃钢雕塑订做鹤壁商业玻璃钢雕塑厦门夏季商场美陈制作香港通过《维护国家安全条例》两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”19岁小伙救下5人后溺亡 多方发声单亲妈妈陷入热恋 14岁儿子报警汪小菲曝离婚始末遭遇山火的松茸之乡雅江山火三名扑火人员牺牲系谣言何赛飞追着代拍打萧美琴窜访捷克 外交部回应卫健委通报少年有偿捐血浆16次猝死手机成瘾是影响睡眠质量重要因素高校汽车撞人致3死16伤 司机系学生315晚会后胖东来又人满为患了小米汽车超级工厂正式揭幕中国拥有亿元资产的家庭达13.3万户周杰伦一审败诉网易男孩8年未见母亲被告知被遗忘许家印被限制高消费饲养员用铁锨驱打大熊猫被辞退男子被猫抓伤后确诊“猫抓病”特朗普无法缴纳4.54亿美元罚金倪萍分享减重40斤方法联合利华开始重组张家界的山上“长”满了韩国人?张立群任西安交通大学校长杨倩无缘巴黎奥运“重生之我在北大当嫡校长”黑马情侣提车了专访95后高颜值猪保姆考生莫言也上北大硕士复试名单了网友洛杉矶偶遇贾玲专家建议不必谈骨泥色变沉迷短剧的人就像掉进了杀猪盘奥巴马现身唐宁街 黑色着装引猜测七年后宇文玥被薅头发捞上岸事业单位女子向同事水杯投不明物质凯特王妃现身!外出购物视频曝光河南驻马店通报西平中学跳楼事件王树国卸任西安交大校长 师生送别恒大被罚41.75亿到底怎么缴男子被流浪猫绊倒 投喂者赔24万房客欠租失踪 房东直发愁西双版纳热带植物园回应蜉蝣大爆发钱人豪晒法院裁定实锤抄袭外国人感慨凌晨的中国很安全胖东来员工每周单休无小长假白宫:哈马斯三号人物被杀测试车高速逃费 小米:已补缴老人退休金被冒领16年 金额超20万

玻璃钢生产厂家 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化