浅谈移动端网页图片预加载方案

所属分类: 网页制作 / html5 阅读数: 952
收藏 0 赞 0 分享

由于公司业务需要,vue制作的网页需要连接智能家居的wifi,然而这种wifi是没有连接互联网的,仅用于手机与家居的对接。这样,就导致了网页在这种wifi下无法加载服务器上的图片。

就此,针对vue单页面系统,我想出来3种方案。

1.在上一页先加载图片,缓存起来,后面的断网页面就能拿到了。

2.做一个页面,上方是路由容器,放置断网后的页面,下方是需要显示的全部图片。这样页面加载时,图片就全部出来了,上方的子路由自然能拿到图片。

3.把图片转换成base64数据保存在localStorage。

第1、2种方案比较简单,在pc上和安卓平台上表现良好。然而在ios上却不显示。

(明明图片都在下方了,上面的却死活不显示)

由此推测,ios系统类浏览器对图片的加载是一个萝卜一个坑的。加载每个图片前会先嗅探其是否在服务器上,存在且未改变就是用缓存显示,没找到就直接404了。因此基于浏览器的缓存策略在断网的情况下并不理想。,需要使用第三种方案。先贴上代码:

  /*  获取图片的base64码
        * @param {obj}img图片dom对象
         * */
        function getBase64Image(img) {
          let canvas = document.createElement("canvas");
          canvas.width = img.width;
          canvas.height = img.height;
          let ctx = canvas.getContext("2d");
          ctx.drawImage(img, 0, 0, img.width, img.height);  //绘制相同图片
          return canvas.toDataURL("image/png"); //转换成base64数据
        }

利用canvas可以很容易实现把图片转换成base64格式。之后只要保存在sessionStorage里面就可以了。之后重新显示图片时,只要设置img的src属性为base64数据就可以了。我在vue项目里面的做法是,创建一个用于转换和保存base64的组件,把slot里面的图片全部转换成base64,并为img标签创建name属性并作为sessionStorage的key;再创建一个组件作为显示组件(只包含一个img标签),设置其name属性和其对应的图片的一样,作为key来取出sessionStorage的base64数据就ok了。

转换和保存组件:

  <!--需要预加载的图片-->
    <save-img-base64>
      <img src="../../assets/img/connect/bind_xiaofang.png" name="bind_xiaofang"/>
      <img src="../../assets/img/connect/bind_allonePro.png" name="bind_allonePro"/>
      <img src="../../assets/img/connect/bind_S20.png" name="bind_S20"/>
      <img src="../../assets/img/connect/bind_S30.png" name="bind_S30"/>
      <img src="../../assets/img/connect/connectStart_xiaofang.png" name="connectStart_xiaofang"/>
      <img src="../../assets/img/connect/connectStart_allonePro.png" name="connectStart_allonePro"/>
      <img src="../../assets/img/connect/connectStart_S20.png" name="connectStart_S20"/>
      <img src="../../assets/img/connect/connectStart_S30.png" name="connectStart_S30"/>
      <img src="../../assets/img/connect/reset_xiaofang.png" name="reset_xiaofang"/>
      <img src="../../assets/img/connect/reset_allonePro.png" name="reset_allonePro"/>
      <img src="../../assets/img/connect/reset_S20.png" name="reset_S20"/>
      <img src="../../assets/img/connect/reset_S30.png" name="reset_S30"/>
      <img src="../../assets/img/connect/network_set.png" name="network_set"/>
      <img src="../../assets/img/connect/phone_wifi.png" name="phone_wifi"/>
      <img src="../../assets/img/connect/tmall.png" name="tmall"/>
    </save-img-base64>

显示组件:

<img-base64 name="network_set"></img-base64>

浏览器sessionStorage情况:

Can I use的表格中可以看出,现代手机浏览器基本兼容canvas,大家可以放心使用。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

HTML5梦幻之旅——炫丽的流星雨效果实现过程

流星出现的时候,人们都喜欢对着它们许愿,因为传说对着流星许下愿望后,愿望就能实现,最近出于兴趣,制作一个拖尾效果,后来想到可以通过拖尾效果来实现一下流星雨的效果
收藏 0 赞 0 分享

5个你不知道的HTML5的接口介绍

尽管当前的主流浏览器已经实现了很多的HTML5新特性,但是很多开发者根本就没注意到这些更简洁,也很有用的API,本系列文章介绍这些接口API,同时也希望能鼓励更多开发者去探索那些还不广为人知的API
收藏 0 赞 0 分享

HTML5 placeholder(空白提示)属性介绍

浏览器引入了许多的HTML5 特性其中我最喜欢的一个就是为input元素引入了placeholder属性,placeholder属性显示引导性文字直到输入框获取输入焦点,当有了用户输入内容后引导性内容将会自动隐藏
收藏 0 赞 0 分享

HTML5 自动聚焦(autofocus)属性使用介绍

一个简单的HTML功能是现在允许我们在页面加载完成后自动将输入焦点定位到需要的元素,通过一个叫做 autofocus的属性完成,感兴趣的朋友可以了解下
收藏 0 赞 0 分享

HTML5新增的Css选择器、伪类介绍

HTML5新增了Css选择器、伪类,本文整理了一些,并给出简单的使用介绍,喜欢html5的朋友可以参考下,希望对大家有所帮助
收藏 0 赞 0 分享

通过Canvas及File API缩放并上传图片完整示例

创建一个只管的用户界面,并允许你控制图片的大小。上传到服务器端的数据,并不需要处理enctype为 multi-part/form-data 的情况,仅仅一个简单的POST表单处理程序就可以了. 好了,下面附上完整的代码示例
收藏 0 赞 0 分享

Canvas与Image互相转换示例代码

本文向大家展示怎样转换Image为canvas,以及canvas如何提取出一个Image,示例代码如下,有此需求的朋友可以参考下,希望对大家有所帮助
收藏 0 赞 0 分享

HTML5的语法变化介绍

HTML5的语法变化主要体现在标签不再区分大小写、元素可以省略结束标签、允许省略属性值的属性等等,感兴趣的朋友可以参考下,希望对大家了解html5有所帮助
收藏 0 赞 0 分享

HTML5 预加载让页面得以快速呈现

预加载是一种浏览器机制,使用浏览器空闲时间来预先下载/加载用户接下来很可能会浏览的页面/资源,当用户访问某个预加载的链接时,如果从缓存命中,页面就得以快速呈现
收藏 0 赞 0 分享

HTML5 input元素类型:email及url介绍

HTML5改进的地方想必大家有所知晓,下面我要介绍的是两个新的input元素类型email和url。让我们跟着代码来看看他们的好处,感兴趣的朋友可以参考下
收藏 0 赞 0 分享
查看更多