中文前端UI框架Kit:超酷的瀑布流特效动画

开发 前端
首先core需要引用kit.js,IE下通过条件注释引入ieFix.js,其他需要引入,array.js 数组扩展(可以不引用),anim.js 动画扩展即可。

Demo地址:http://xueduany.github.com/KitJs/KitJs/demo/Waterfall/demo.html

image

(一)KitJs瀑布流组件特点

1. 瀑布流形式呈现图片加载,鼠标滚动到底加载新的数据

2. 瀑布条数随窗口大小改变而改变,支持任意缩放窗口

(二)使用方法

core需要引用kit.js,IE下通过条件注释引入ieFix.js

其他需要引入

array.js 数组扩展(可以不引用)

anim.js 动画扩展即可,

至于demo中的semitransparentloading.js是用来做半透明loading的,io.js是用来跨域取图片数据的,这个load方法可以自定义

最简单的加载方式,比如

  1. var currentPage = 1;  
  2.     var waterfall = new $kit.ui.Waterfall({  
  3.         container : $kit.el('.kitjs-waterfall-container')[0],  
  4.         load : function(success, end) {  
  5.             //$('#loadingPins').show();  
  6.             $kit.io.josnp({  
  7.                 url : 'http://api.flickr.com/services/rest/?method=flickr.photos.search&api_key=5d93c2e473e39e9307e86d4a01381266&tags=rose&page=' + currentPage + '&per_page=20&format=json&_ksTS=1339665079110_92&jsoncallback=dealWithJSONPData',  
  8.                 onSuccess : function() {  
  9.                     currentPage = window.loadedData.photos.page + 1;  
  10.                     //alert(window.loadedData.photos.photo.length);  
  11.                     var items = [];  
  12.                     $kit.each(window.loadedData.photos.photo, function(item) {  
  13.                         item.height = Math.round(Math.random() * (300 - 180) + 180);  
  14.                         // fake height  
  15.                         items.push($kit.newHTML($kit.tpl(['<div class="kitjs-waterfall" data-id="${id}">'//  
  16.                         '<a href="http://farm/${farm}.static.flickr.com/${server}/${id}_${secret}_m.jpg" class="image" target="_blank">', //  
  17.                         '<img height="${height}" alt="${title}" src="http://farm/${farm}.static.flickr.com/${server}/${id}_${secret}_m.jpg"/>', //  
  18.                         '</a>'//  
  19.                         '<p class="description">${title}</p>'//  
  20.                         '</div>'//  
  21.                         ].join(''), item)).childNodes[0]);  
  22.                     });  
  23.                     success(items);  
  24.                     window.timeoutLoading = setTimeout(function() {  
  25.                         if(window.loading) {  
  26.                             window.loading.destory();  
  27.                             window.loading = null;  
  28.                         }  
  29.                     }, 600)  
  30.                 }  
  31.             })  
  32.         },  
  33.         minColCount : 2,  
  34.         colWidth : 228  
  35.       });  
  36.     waterfall.ev({  
  37.         ev : 'loadData',  
  38.         fn : function() {  
  39.             if(window.timeoutLoading) {  
  40.                 clearTimeout(window.timeoutLoading);  
  41.                 window.timeoutLoading = null;  
  42.             }  
  43.             if(window.loading == null) {  
  44.                 window.loading = new $kit.ui.SemitransparentLoading();  
  45.             }  
  46.         }  
  47.     });  
  48.     waterfall.ev({  
  49.         ev : 'resizeBegin',  
  50.         fn : function() {  
  51.             if(window.timeoutLoading) {  
  52.                 clearTimeout(window.timeoutLoading);  
  53.                 window.timeoutLoading = null;  
  54.             }  
  55.             if(window.loading == null) {  
  56.                 window.loading = new $kit.ui.SemitransparentLoading();  
  57.             }  
  58.         }  
  59.     });  
  60.     waterfall.ev({  
  61.         ev : 'resizeEnd',  
  62.         fn : function() {  
  63.             window.timeoutLoading = setTimeout(function() {  
  64.                 if(window.loading) {  
  65.                     window.loading.destory();  
  66.                     window.loading = null;  
  67.                 }  
  68.             }, 600)  
  69.         }  
  70.     });  
  71.  

指定一个容器,一个加载数据的方法,最小瀑布列数,瀑布宽度(这个是固定的)

在加载方法里面,初始化单个图片容器的Dom节点,需要显示指明节点高度,将height,domNode放入一个数组中,调用load方法的回调参数succes

(三)自定义事件

目前支持三个自定义事件,load触发之前会有一个load事件,还有缩放窗口的时候,有resizeBegin和resizeEnd事件,可以用来做loading动画。

经过几个月的努力,现在kit已经有了完整的底层以及基础UI控件体系,包括

1. 完整的dom api

2. 强化的anim动画类,支持所有的Css动画,包括Css3以及IE Hacker

3. 平衡了IE与W3C的range对象了,完美兼容了W3C的所有的api,实现了跨浏览器的bookmark同步

4. 完整的OO体系,属性getter,setter,对象继承,单例,模块

5. 强大的模板系统,支持循环,if else条件判断

6. 齐全的浏览器侦测,手持设备,PC等等

7. 基础的UI体系,可以支持复杂的页面组件

包括不限于,蒙版,浮动层,对话框,拖拽,高级自定义增强事件,增强动画,日历,表单,验证,瀑布流...

8. 基础的log,安全沙箱,打包工具,自动化脚本等。

原文链接:http://www.cnblogs.com/xueduanyang/archive/2012/06/15/2550062.html

【编辑推荐】

  1. 中文前端UI框架Kit:摇头动画
  2. JavaScript图片变换效果(IE only)
  3. JavaScript提升网页加载速度
  4. JavaScript马赛克遮罩图片幻灯片切换类
  5. 看JavaScript如何实现页面自适
责任编辑:张伟 来源: 薛端阳的博客
相关推荐

2012-06-14 17:06:38

JavaScript

2024-09-03 17:04:15

前端算法布局

2012-03-28 09:49:55

WEB特效

2022-07-27 10:36:13

前端UI框架

2019-01-31 11:11:30

前端开发框架

2022-07-08 09:55:54

CSS转场动画

2015-02-26 18:09:29

WaterFall V瀑布流Dynamic Gri

2012-05-02 13:53:00

JavaScript

2024-08-19 14:01:00

2014-06-27 09:47:48

Bootstrap

2014-07-28 16:05:42

云适配

2013-04-03 15:45:51

Android瀑布流android_wat

2021-02-23 15:24:51

腾讯组件开源

2015-12-07 10:00:13

HTML5Loading动画

2014-07-10 10:02:01

iOSHome Kit框架

2022-08-01 12:53:30

前端动画

2022-06-09 10:27:40

前端框架开源

2023-01-05 13:36:41

Script优化任务

2022-03-09 07:10:50

Quarkus框架项目

2023-01-04 15:24:46

ACE组件UI布局
点赞
收藏

51CTO技术栈公众号