zoukankan      html  css  js  c++  java
  • 基于jQuery封装一个瀑布流插件

    /*封装一个瀑布流插件*/
    (function($){
        $.fn.WaterFall = function(){
            /*这是你初始化  调用这个方法的时候的  那个jquery选着到的dom对象 this*/
            /*$this 拿到的瀑布流容器  中有需要需要去做定位的盒子*/
            var $this = $(this);
    
            /*拿到容器的宽度*/
            var parentWidth = $this.width();
    
            /*瀑布流容器当中的item*/
            var items = $this.children();
    
            /*子容器的宽度*/
            var childWidth = items.width();
    
            /*多少列*/
            var columnCount = 5;
    
            /*间距*/
            var space = (parentWidth - childWidth * columnCount)/(columnCount-1);
    
            /*核心布局代码*/
            /*
            * 1.第一排的盒子 top定位  都是0
            * 2.距离左边的距离  根据当前所属的列  第几列 5  索引 4*宽度+间距
            * 3.计算top的定位  找到最矮的那列  把它追加上去
            * 4.容器是没有高度的  需要计算最高的那列 设置高度
            * 【怎么样实时的记录每一列的高度】 需要有一个记录每一列高度的变量  数组记录五裂的高度
            * */
    
            var colArray = [];
    
            /*遍历所有的盒子*/
            $.each(items,function(i,item){
                /*当前盒子*/
                var $item = $(item);
                /*索引是0-4就是五个第一排的盒子*/
                if(i < 5){
                    /*初始化数组*/
                    colArray[i] = $item.height();
                    /*第一排的盒子 定位*/
                    $item.css({
                        top:0,
                        left:i*( childWidth + space )
                    });
                }else{
                    /*计算定位*/
                    /*3.计算top的定位  找到最矮的那列  把它追加上去*/
                    var minItem = colArray[0];/*最小的高度*/
                    var minIndex = 0;/*最下的那列的索引*/
                    for(var j = 0 ; j < colArray.length ; j ++){
                        if(minItem > colArray[j]){
                            minItem = colArray[j];
                            minIndex = j;
                        }
                    }
                    //console.log(minItem);
                    /*因为要定位left  需要这列的索引*/
                    $item.css({
                        top:minItem + space,
                        left:minIndex * (childWidth + space)
                    });
                    /*colArray 高度变了 所以要重新设置*/
                    colArray[minIndex] = minItem + space + $item.height();
                }
            });
    
            /*布局完成在来设置容器的高度*/
            console.log(colArray);
            /* 4.容器是没有高度的  需要计算最高的那列 设置高度*/
            var maxItem = colArray[0];
            for(var i = 0 ; i < colArray.length ; i ++){
                if(maxItem < colArray[i]){
                    maxItem = colArray[i];
                }
            }
            $this.height(maxItem);
    
    
        }
    })(jQuery);
  • 相关阅读:
    学习设计模式之中介者模式
    学习设计模式之责任链模式
    学习设计模式之命令模式
    学习设计模式之桥接模式
    学习设计模式之单例模式
    学习设计模式之迭代器模式
    Spring 源码学习——注册 BeanDefinition
    Html.DropDownListFor
    Home vs2013
    Jquery 操作页面中iframe自动跟随窗口大小变化,而页面不出现滚动条,只在iframe内部出滚动条
  • 原文地址:https://www.cnblogs.com/lsy0403/p/5914257.html
Copyright © 2011-2022 走看看