瀑布流图片以及预加载

在web项目开发中,经常遇到需要加载大量的图片,为了�提高用户体验,我们可以使用预加载技术把图片预先加载到浏览器中,这样用户使用时,会感觉网速很快,接下来给大家介绍一种简单常用的预加载方法。

瀑布流的实现

1.html代码很少,如下:

    <div>
        <progress min="0" max="100" value="0" id="progress"></progress>
    </div>
    <div class="box"></div>

2.首先介绍一下img的几个方法。

  1. onload方法,它代表图片加载完毕之后执行的函数,下面会介绍;
  2. onerror方法, 图片加载错误执行的函数
            img.onerror = function(){
                console.log("加载图片出错了");
            }       
  1. onabout方法,图片被终止加载/放弃加载图片 执行的函数
img.onabout = function(){
                console.log("握不住的沙,不如就扬了他");
            }

3. 创建瀑布流的函数
如果不加img.onload方法,所有图片会全部叠加在上面,不能从上到下的铺开,是因为img加载需要时间,而代码执行完毕的时间很短很短,这时获取到的img.offsetHeight就为零,这样图片就会挤在一起。
使用onload方法是加载一张图片完毕后或取img.offsetHeight,这样就能获取到图片的高度了。
下面使用函数的递归实现的

      function createImg(){
            var img = document.createElement("img");
//          img.src = imgArr[i].src;
            img.src = "img/P_0" + i + ".jpg";
            i++;
            var minIndex = 0;
            for(var j = 1; j < heightArr.length ;j++){
                if(heightArr[minIndex] > heightArr[j]){
                    minIndex = j;
                }
            }
            img.style.left = minIndex * 210 + "px";
            img.style.top = heightArr[minIndex] + "px";
            img.innerHTML = i;
            box.appendChild(img);
            // onload 代表图片加载完毕之后执行的函数
            img.onload = function(){
                progress.value = (i / 16)*100 ;
                console.log(img.offsetHeight);
                heightArr[minIndex] += (img.offsetHeight+10);
                if(i >= 16){
                    return ;
                 }
                createImg();
            }               
       }

结果图如下:


瀑布流.png

图片预加载

1.在图片展示到页面之前预先全部加载出来
其中 :var readyImg = new Image(); 语句也是创建img标签的一种写法;和document.createElement("img") 等价。
使用for循环创建所有的img标签,通过设置src属性来加载所有的图片,在所有图片加载完毕后,调用createImg(); 函数

       for(var j = 0 ; j < 16 ; j++){
            var readyImg = new Image();
            imgArr.push(readyImg);
            // 图片是在设置src之后就开始请求
            readyImg.src = "img/P_0" + j + ".jpg";
            readyImg.onload = function(){
                count++;
                progress.value = (count / 16)*100;
                if(count == 16){
                    console.log("所有图片加载成功");
                    createImg()
                }
                
            }
       }

这样在用户网速不好时,使用预加载,就能使用户浏览网站时不出现一些bug,或者页面的布局紊乱,能很好的提高用户体验

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容

  • 所谓瀑布流,就是图片分几列有规律的排列,但是这里的排列是有要求的,普通的浮动布局会使图片与图片之间有很多的空隙,这...
    小飞侠zzr阅读 814评论 0 0
  • 课程前言: 慕课网 --图片预加载 图片预加载的特点: ( 1、网站的Loading页 2、局部图片的加载--表情...
    一树青枫阅读 3,644评论 0 2
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,413评论 25 707
  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 7,716评论 2 17
  • 陈佳瑞,一个很倔强的女孩子,六岁前都是奶奶带大的!老人家几乎不说孩子什么做的不对。孩子上学遇到不开心的事,不想上课...
    蜗牛与黄鹂阅读 460评论 0 0