kissy瀑布流学习笔记

 

KISSY 是由淘宝前端攻城师们发起创建的一个开源 JS 类库。

她遵循的原则是 小巧灵活、简洁实用、愉悦编码、快乐开发。

本次主要是使用kissy的waterfall 实现瀑布流效果。 

 

 

首先是查看了kissy的介绍和api文档,了解了大致的用法,然后下载了waterfall的demo到本地运行测试,最后将代码移植在自己的项目中使用。

 

基本的介绍和使用,api里都有说明,这里主要说说遇到的问题

kissy和jquery类似,首页要引入基础的js库也就是kissy.js,然后在根据自己使用中用的功能引用不同的js,如果我这里要使用瀑布流,并且是动态加载的。所以就引用了base.js loader.js waterfall.js这些demo中都有,当然有了这些js文件,瀑布流的效果已经可以实现。可以对一个最基本的板块进行瀑布流排版

如:

 

KISSY.use("waterfall", function (S, Waterfall) {

      new Waterfall({

        container: "#ColumnContainer", //节点容器

        minColCount: 4,

        colWidth: 320 //每列的宽度

      });

    });

 

 

具体配置参数,参考api文档。


但发现demo上,是可以动态加载数据的,并且发现kissy提供一个内容模版的功能,可以设定好动加载数据的模版,网模版里填写数据即可,这个需要用到template.js,也是一个非常使用的插件。

demo里的这段代码就是模版

 

<script type="tpl" id="tpl">
  <div class="pin ks-waterfall" data-id="">
    <a href="#" class="image">
      <img height="{{height}}" alt="" src="{{photopath}}"/>
    </a>
    <p class="description"></p>
    <p>
      <button class="del">删除</button>
      <button class="grow">增高</button>
    </p>
  </div>
</script>
 

 

 

里面被"{{","}}"这个包含的都会被动态加载返回的json数据里的同名替换成对应的值。对于需要动态加载数据的需要Waterfall.Loader,直接在代码中备注说明吧

demo中的html并没有引入template.js仍可以使用,但我一直到自己的工程就必须在页面上引入这个js,还有就是demo有用到Button这个插件,但我引入button.js后仍然不能正常运行,最后只好将Button这个给去掉就正常了,原因不清楚,如有高人知道,请赐教 )最后使用修改后的js备注说明

 

KISSY.use("waterfall,ajax,template", function (S, Waterfall, io, Template) {
      var tpl = Template($('#tpl').html()); //定义内容模版
      var nextpage = 1;
        var waterfall = new Waterfall.Loader({
            container: "#ColumnContainer", //节点容器 
            adjustEffect:{
              duration:0.5,
              easing:"easeInStrong"
            },
            diff :10, //api文档中如此解释  滚动时, 当最小高度的列超过在屏幕高度+已滚动高度+diff时, 会去加载更多数据 ,发现如果不加此值,拖动滚动条是,不会自动加载更多


            load:function (success, end) {
              $('#loadingPins').show();
              S.ajax({
                data:{
                  'from':'water',
                  'page':nextpage,
                  'per_page':20,
                  'format':'json'
                },
                url:'/photo/photos.ydd',
                dataType:"json",
                /*jsonp:"jsoncallback",*/  
                success:function (d) {
                  // 如果数据错误, 则立即结束
                  /*if (d['stat'] !== 'ok') {
                    alert('load data error!');
                    end();
                    return;
                  }
                  // 如果到最后一页了, 也结束加载
                  nextpage = d['photos'].page + 1;
                  if (nextpage > d['photos'].pages) {
                    end();
                    return;
                  }*/
                  // 拼装每页数据
                  var items = [];
                  S.each(d, function (item) {
                    item.height = Math.round(Math.random() * (300 - 180) + 180); // fake height  设置瀑布流假的高度,每个高度不一样,做出瀑布流的效果
                    items.push(tpl.render(item));  //tpl.render(item) 前面提到的通过模版生成内容。
                  });
                  success(items);
                },
                complete:function () {
                  $('#loadingPins').hide();
                }
              });
            },
            minColCount:2,
            colWidth:228
          });

          waterfall.on('adjustComplete', function () {
            S.log('after adjust complete!');
          });
          waterfall.on('addComplete', function () {
            S.log('after add complete!');
          });
          // scrollTo
          $('#BackToTop').on('click', function (e) {
            e.halt();
            e.preventDefault();
            $(window).stop();
            $(window).animate({
              scrollTop:0
            }, 1, "easeOut");
          });

          $("#ColumnContainer").on("click", ".del", function (event) {

            var w = $(this).parent().parent(".ks-waterfall");
            waterfall.removeItem(w, {
              callback:function () {
                alert("删除完毕");
              }
            });
          });


          $("#ColumnContainer").on("click", ".grow", function (event) {
            var w = $(this).parent().parent(".ks-waterfall");
            waterfall.adjustItem(w, {
              process:function () {
                w.append("<img src='http://farm9.static.flickr.com/8167/7688895968_25ed78629e_m.jpg' width='220' height='200px;'>");
              },
              callback:function () {
                alert("调整完毕");
              }
            });
          });

    });
 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值