最近做资讯详情页面的优化,由于资讯详情页面正文内容是后端返回的html
,如果图片特别多,尤其是有很多gif
图片,那加载的速度非常慢,因此进行优化。
一. 优化思路
- 首先将返回的
html
的图片地址替换为本地图片的默认图,然后用原生的iOS
去下载图片,下载成功之后替换掉默认图。
二. 遇到的问题
思路看起来很简单,但这里遇到了访问权限问题,因为webkit
是单独的进程,访问当前app
的沙盒路径,是需要权限的,这里有三种解决方法。
方法一:
- 通过
http
的方式访问沙盒存储的图片,这个可以通过第三方GCDWebServer
来实现
方法二:
通过系统方法
- (nullable WKNavigation *)loadFileURL:(NSURL *)URL allowingReadAccessToURL:(NSURL *)readAccessURL
(支持iOS9及以上系统), 来声明访问权限。这里可以在沙盒存储目录下,放置
html
的文件,然后将返回的html
先进行处理,处理过程如下:首先依据
图片url
地址去获取md5值
,然后依据md5值
,去沙盒存储路径判断以该md5值
为名称的图片是否存在,如果存在将图片url
地址替换为沙盒目录下该md5值
为名称的图片地址,如果不存在,则将图片url
地址替换为沙盒目录下默认图片地址然后生成给
html
的图片标签设置id
,id值
为md5值
,然后用原生去下载为缓存的图片,下载成功后,依据id值
去替换路径。然后将处理后的
html
文本,写入到原先存放的html文件
内,然后用webview
去加载对应的路径和声明访问权限。
方法三:
- 通过将沙盒路径下的图片转换为
base64
编码的数据,去显示。
这里采用的是方法二来处理,因为现在最低支持的系统版本是iOS9
。