最近做一个项目需要用到jQuery Waterfall插件-瀑布流图片显示
jquery waterfall plugin,like Pinterest 、 huaban.com 、 faxianla.com
下载地址: waterfall plugin
如何使用
第一步:
添加html代码
<div id="container"></div>
第二步:
引入需要的js
<script src="/path/jquery.min.js"></script> <script src="/path/handlebars.js"></script> <script src="/path/waterfall.min.js"></script>
第三步:
添加模板
<script id="waterfall-tpl" type="text/x-handlebars-template"> //template content </script>
第四步:
script的实现如下:
$(‘#container‘).waterfall({ itemCls: ‘waterfall-item‘, prefix: ‘waterfall‘, fitWidth: true, colWidth: 240, gutterWidth: 10, gutterHeight: 10, align: ‘center‘, minCol: 1, maxCol: undefined, maxPage: undefined, bufferPixel: -50, containerStyle: { position: ‘relative‘ }, resizable: true, isFadeIn: false, isAnimated: false, animationOptions: { }, isAutoPrefill: true, checkImagesLoaded: true, path: undefined, dataType: ‘json‘, params: {}, loadingMsg: ‘<div style="text-align:center;padding:10px 0; color:#999;"><img src="" alt=""><br />Loading...</div>‘, state: { isDuringAjax: false, isProcessingData: false, isResizing: false, curPage: 1 }, // callbacks callbacks: { /* * loadingStart * @param {Object} loading $(‘#waterfall-loading‘) */ loadingStart: function($loading) { $loading.show(); //console.log(‘loading‘, ‘start‘); }, /* * loadingFinished * @param {Object} loading $(‘#waterfall-loading‘) * @param {Boolean} isBeyondMaxPage */ loadingFinished: function($loading, isBeyondMaxPage) { if ( !isBeyondMaxPage ) { $loading.fadeOut(); //console.log(‘loading finished‘); } else { //console.log(‘loading isBeyondMaxPage‘); $loading.remove(); } }, /* * loadingError * @param {String} xhr , "end" "error" */ loadingError: function($message, xhr) { $message.html(‘Data load faild, please try again later.‘); }, /* * renderData * @param {String} data * @param {String} dataType , "json", "jsonp", "html" */ renderData: function (data, dataType) { var tpl, template; if ( dataType === ‘json‘ || dataType === ‘jsonp‘ ) { // json or jsonp format tpl = $(‘#waterfall-tpl‘).html(); template = Handlebars.compile(tpl); return template(data); } else { // html format return data; } } }, debug: false });
第五步:
设置调用数据的服务
第六步:
DEMO实例如下:
原文: http://blog.csdn.net/websites/article/details/45094407
谢谢关注websites博客!
时间: 2024-10-15 21:48:23