redef.js 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. 参数
  3. parent 放置瀑布流元素的容器,默认为 $("waterfall")
  4. container 放置瀑布流的父容器,默认为 $("threadlist")
  5. maxcolumn 最多多少列,默认为 0 不限制
  6. space 图片间距,默认为 10
  7. index 从第几张开始排列,默认为 0
  8. tag 瀑布流元素的 tagName,默认为 li
  9. columnsheight 存放列高度的数组
  10. 返回值
  11. index 当前瀑布流已经排列了多少个图片
  12. totalwidth 当前瀑布流的总宽度
  13. totalheight 当前瀑布流的总高度
  14. columnsheight 存放瀑布流列高的数组
  15. */
  16. function waterfall(v) {
  17. var v = typeof(v) == "undefined" ? {} : v;
  18. var column = 1;
  19. var totalwidth = typeof(v.totalwidth) == "undefined" ? 0 : v.totalwidth;
  20. var totalheight = typeof(v.totalheight) == "undefined" ? 0 : v.totalheight;
  21. var parent = typeof(v.parent) == "undefined" ? $("waterfall") : v.parent;
  22. var container = typeof(v.container) == "undefined" ? $("threadlist") : v.container;
  23. var maxcolumn = typeof(v.maxcolumn) == "undefined" ? 0 : v.maxcolumn;
  24. var space = typeof(v.space) == "undefined" ? 10 : v.space;
  25. var index = typeof(v.index) == "undefined" ? 0 : v.index;
  26. var tag = typeof(v.tag) == "undefined" ? "li" : v.tag;
  27. var columnsheight = typeof(v.columnsheight) == "undefined" ? [] : v.columnsheight;
  28. function waterfallMin() {
  29. var min = 0;
  30. var index = 0;
  31. if(columnsheight.length > 0) {
  32. min = Math.min.apply({}, columnsheight);
  33. for(var i = 0, j = columnsheight.length; i < j; i++) {
  34. if(columnsheight[i] == min) {
  35. index = i;
  36. break;
  37. }
  38. }
  39. }
  40. return {"value": min, "index": index};
  41. }
  42. function waterfallMax() {
  43. return Math.max.apply({}, columnsheight);
  44. }
  45. var mincolumn = {"value": 0, "index": 0};
  46. var totalelem = [];
  47. var singlewidth = 0;
  48. totalelem = parent.getElementsByTagName(tag);
  49. if(totalelem.length > 0) {
  50. column = Math.floor((container.offsetWidth - space) / (totalelem[0].offsetWidth + space));
  51. if(maxcolumn && column > maxcolumn) {
  52. column = maxcolumn;
  53. }
  54. if(!column) {
  55. column = 1;
  56. }
  57. if(columnsheight.length != column) {
  58. columnsheight = [];
  59. for(var i = 0; i < column; i++) {
  60. columnsheight[i] = 0;
  61. }
  62. index = 0;
  63. }
  64. singlewidth = totalelem[0].offsetWidth + space;
  65. totalwidth = singlewidth * column - space;
  66. for(var i = index, j = totalelem.length; i < j; i++) {
  67. mincolumn = waterfallMin();
  68. totalelem[i].style.position = "absolute";
  69. totalelem[i].style.left = singlewidth * mincolumn.index + "px";
  70. totalelem[i].style.top = mincolumn.value + "px";
  71. columnsheight[mincolumn.index] = columnsheight[mincolumn.index] + totalelem[i].offsetHeight + space;
  72. totalheight = Math.max(totalheight, waterfallMax());
  73. index++;
  74. }
  75. parent.style.height = totalheight + "px";
  76. parent.style.width = totalwidth + "px";
  77. }
  78. return {"index": index, "totalwidth": totalwidth, "totalheight": totalheight, "columnsheight" : columnsheight};
  79. }