美文网首页
JS填坑积累

JS填坑积累

作者: Oo曾小曾oO | 来源:发表于2016-07-21 15:13 被阅读0次

图片lazy加载

// @description 准备为图片预加载使用的插件
// 使用的图片容器css类名为lazy-load-wrap
// 图片真实地址为data-lazy-src
// 当lazy-load-wrap容器进入视口,则开始替换容器内所有需要延迟加载的图片路径,并更改容器的加载状态
//第一种方法
$.fn.compassLazyLoad=function(){
        var _HEIGHT=window.innerHeight,

        _lazyLoadWrap=$('.lazy-load-wrap');

        var methods={
        setOffsetTop:function(){
            $.each(_lazyLoadWrap,function(i,n){
                $(n).attr({
                    'top':n.offsetTop-_HEIGHT,
                    'status':'wait'
                });
            })
        },
        isShow:function(){
            var _scrollTop=$(window).scrollTop;
            //利用image容器判断是否进入视口,而非image本身
            $.each(_lazyLoadWrap,function(){
                var _that=$(this);
                if (_that.attr('status')==='done') {
                    return;
                };
                if (_that.attr('top')<=_scrollTop) {
                    _that.find('img[data-lazy-src]').each(function(i,n){
                        n.src=$(n).data('lazy-src');
                    });
                    _that.attr('status','done');
                };
            })
        },
        scroll:function(){
            $(window).on('scroll',function(){
                methods.isShow();
            });
        },
        init:function(){
            methods.setOffsetTop();
            methods.isShow();
            methods.scroll();
        }
    };
    methods.init();

}

//第二种方法
var exist=(function($){
var timer=null,
temp=[].slice.call($('.container'));
ret={};

for(var i=0,len=temp.length-1;i<=len;i++){
    ret[i]=temp[i];
}
var isExist=function(winTop,winEnd){
    for(var i in ret){
        console.log(ret);
        var item=ret[i],
        eleTop=item.offsetTop,
        eleEnd=eleTop+item.offsetHeight;

        if((eleTop>winTop&&eleTop<=winEnd)||(eleEnd>winTop&&eleEnd<=winEnd)){
            $(item).css('background','none');
            new Tab($(item).attr('id'),data).init;
            delete ret[i];
        }
    }
}
return {
    timer:timer;
    isExist:isExist;
};
})($);

//第三种方法
Zepto(function ($) {
    var swiper = new Swiper('.swiper-container', {
        pagination: '.swiper-pagination',
        paginationClickable: true,
        autoplay: 3000,
        loop: true,
        autoplayDisableOnInteraction: false
    });
    (function lazyLoad() {
        var imgs = $(".lazyLoad");
        var src = '';
        $.each(imgs, function (index, item) {
            src = $(item).attr('data-src');
            $(item).attr('src', src);
        });
    })();
});
$(function () {
    var lazyLoadTimerId = null;
    /// 智能加载事件
    $(window).bind("scroll", function () {
        clearTimeout(lazyLoadTimerId);
        lazyLoadTimerId = setTimeout(function () {
            // 延迟加载所有图片
            var isHttp = (location.protocol === "http:");
            $("#ym_images img").each(function () {
                var self = $(this);
                if (self.filter(":above-the-fold").length > 0) {
                    var originUrl = self.attr("data-original");
                    self.attr("src", originUrl);
                }
            });
        }, 500);
    });
});

相关文章

  • JS填坑积累

    图片lazy加载

  • js基础填坑

    js学习之路:第一阶段:《JavaScript DOM编程艺术》第二阶段:《JavaScript高级程序设计》第三...

  • js 填坑代码

    以下是常用的代码收集,学习用。转自豪情博客园 1. PC - js 返回指定范围的随机数(m-n之间)的公式 re...

  • JS toFixed()填坑

    问题 1、在JS中四舍五入的函数 toFixed(n) , n为要保留的小数位数。 n为0~20,当n超过20的时...

  • 选择待选框选项到已选框

    先看实现效果图 jsp代码 js代码 具体到后台实现再填坑吧~~

  • node.js填坑

    关于在node.js 导出模块的问题填坑 构造函数 的导出跟es6的class类导出的顺序问题 module.ex...

  • 再挖个坑,明天填,push的

    再挖个坑,明天填,push的 再挖个坑,明天填,push的 再挖个坑,明天填,push的 再挖个坑,明天填,pus...

  • Wendy Shijia 的「 Escher's Gallery

    开始填坑。太多坑没填以致可以从容选择先填哪个,然而也忘了坑长什么样、怎么填。不过还是希望该填的坑能尽量于月底前填完...

  • 一年很长,也很短

    入简书已有一年,这里挖了坑,没有及时填,没能及时填,总觉词不达意。积累不足是一大短板,补之急,缓为之。 ...

  • 填坑之路:Knockout.js

    1. applyBindings 2. observable ko.observable监控的对象都是方法(函数)...

网友评论

      本文标题:JS填坑积累

      本文链接:https://www.haomeiwen.com/subject/gvubjttx.html