30 |
31 | 36 | 37 |
38 |
39 |

jquery-paged-scroll - different approach for infinite scroll.Replace your old pagination easily.

40 | 41 |

Inspiration

42 | 43 |

Today we have a couple of good jquery "infinite scroll" plugins ,so why I wrote another one ?

44 | 45 |

Different approach - for different use case.

46 | 47 |

Most of existing plugins rely on the fact that you already have some numeric paging implemented in order to query it through provided selector for current,next and previous page and loading this page inside some element or calling callback. 48 | For my project such approach was overhead, because I wanted only to display paged result set (json returned from public youtube and flickr api's) and replace current pagination using the "infinite scroll" interaction design pattern,where plugin will be responsible for calculation of current page according to scroll progress,so functionality can be reused. 49 | I think the plugin will help to easily adopt infinite scroll especially in cases when working with paged result retrieved through ajax call . Because of flexibility given by the fact that plugin just calling user callback ,also http POST can be used to retrieve results.

50 | 51 |

Performance

52 | 53 |

Performance optimizations - attaching the handlers to scroll event need to be handled carefully by developer,because it can easily take the browser down. 54 | Don't believe me ? Just take a look on the John Resig article,where he explains how Twitter became unusable because of primitive handling of scroll event.

55 | 56 |

Multiple plugin instances

57 | 58 |

Support for multiple plugins on the page listening on the scroll event of the same element,but preserving their own pagination state. 59 | Look on this example: 60 | We can see 2 tabs ("Videos" and "Photos"),code responsible for tab functionality subscribes to window scroll event via the plugin and provides the callback ,but only the the callback of "visible" tab is called.

61 | 62 |

Scroll inside element

63 | 64 |

Support scrolling on different elements,not only window scroll. 65 | div,p - are supported and tested for now.

66 | 67 |

Demo:

68 | Real world example.KeenTour Travel startup - uses plugin to navigate through videos and photos using infinite scroll pattern. 69 |

Playground:

70 | Examples to play with. 71 |
debug option enabled.
72 | Scroll on window 73 | Scroll inside element 74 | 75 | 76 | 77 | 78 |

Getting Started

79 | 80 |

Download the production or development version.

81 | 82 |

Documentation

83 | 84 |

Options :

85 | 86 |
$('.selector').pagedScroll{
 87 | 
 88 |             /*
 89 |                      required
 90 |                      your  callback which called which will be called with current page number
 91 |                      */
 92 |                     handleScroll:function (page, container, doneCallback) {
 93 |                         return true;
 94 |                     },
 95 | 
 96 |                     /*
 97 |                      required
 98 |                      amount of pixels or amount of percent of container (calculated to pixel by plugin) from bottom, to start scroll
 99 |                      */
100 |                     triggerFromBottom:'10%',
101 | 
102 |                     /*
103 |                         html to show when loading
104 |                     */
105 |                     loading : {
106 |                          html  : '<div class="paged-scroll-loading"><img alt="Loading..." src="" /></div>'
107 |                     },
108 | 
109 |                     /*
110 |                      required
111 |                      element where content will be inserted
112 |                      */
113 |                     targetElement:null,
114 | 
115 |                     /*
116 |                      optional,default is 0
117 |                      page number to start with
118 |                      */
119 |                     startPage:0,
120 | 
121 |                     /*
122 |                      optional
123 |                      null means infinite scroll
124 |                      */
125 |                     pagesToScroll:null,
126 | 
127 |                     /*  optional
128 |                      before page hook ,if returns false execution stops
129 |                      */
130 |                     beforePageChanged:function (page, container) {
131 |                         return true;
132 |                     },
133 | 
134 |                     /*
135 |                      optional
136 |                      after page scroll calback
137 |                      */
138 |                     afterPageChanged:function (page, container) {
139 |                         return true;
140 |                     },
141 | 
142 |                     /*
143 |                      optional
144 |                      NOT RECOMMENDED to CHANGE!!!
145 |                      default : true
146 |                      if scroll optimization used ,plugin will not access DOM each time scroll is triggered and will save a lot of overhead,because of not calling callback logic each time
147 |                      */
148 |                     useScrollOptimization:true,
149 | 
150 |                     /*
151 |                      timeout in milliseconds to use in order to check  if scroll change is significant enough to call the "handleScroll" callback
152 |                      */
153 |                     checkScrollChange:500,
154 | 
155 |                     /*
156 |                         frequency to check that target html is checked
157 |                     */
158 |                     monitorChangeInterval : 300,
159 | 
160 |                     /*
161 |                      if monitor target element where finally generated content is inserted
162 | 
163 |                      */
164 |                     monitorTargetChange:true,
165 |                     /*
166 |                      if use debug
167 |                      */
168 |                     debug:false
169 | 
170 |         }
171 | 
172 | 173 |

Examples

174 | 175 |
//Call handleScroll function each time user scrolls reach the position which is  : 10px from document bottom.Do this <b>yourLogic.totalNumberOfPages</b> times.
176 | // Your logic will insert newly generated html to <b>$('#element')</b> DOM element.
177 | $(window).paged_scroll({
178 |         handleScroll:function (page,container,doneCallback) {
179 |             yourLogic.getData(function(data){
180 |               var html = yourLogic.parseData(data);
181 |               $('#element').append(html);
182 |             });
183 | 
184 | 
185 |         },
186 |         triggerFromBottom:'10px',
187 |         targetElement : $('#element')
188 |         loader:'<div class="loader">Loading next page ...</div>',
189 |         pagesToScroll: yourLogic.totalNumberOfPages,
190 | 
191 | 
192 |     });
193 | 
194 | 195 |
//Scroll on DOM element supported
196 | //Call handleScroll function each time user scrolls reach the position  which equals to  : 10% of the target element.Infinite scroll because pagesToScroll is not specified.
197 | // Your logic will insert newly generated html to $('#element') DOM element.
198 | $('#element').paged_scroll({
199 |         handleScroll:function (page,container,doneCallback) {
200 |             yourLogic.getData(function(data){
201 |               var html = yourLogic.parseData(data);
202 |               $('#element').append(html);
203 |             });
204 | 
205 | 
206 |         },
207 |         triggerFromBottom:'10%',
208 |         targetElement : $('#element')
209 |         loader:'<div class="loader">Loading next page ...</div>'
210 | 
211 |     });
212 | 
213 | 214 |
215 | //Your don't want that plugin will monitor the change of targetElement and prefer to signal that content is loaded by calling  doneCallback().
216 | $('#element').paged_scroll({
217 |         handleScroll:function (page,container,doneCallback) {
218 |             yourLogic.getData(function(data){
219 |               var html = yourLogic.parseData(data);
220 |               $('#element').append(html);
221 |               doneCallback();
222 |             });
223 | 
224 | 
225 |         },
226 |         triggerFromBottom:'10%',
227 |         targetElement : $('#element')
228 |         loader:'<div class="loader">Loading next page ...</div>',
229 |         pagesToScroll: yourLogic.totalNumberOfPages,
230 |         monitorTargetChange : false
231 | 
232 | 
233 |     });
234 | 
235 | 236 |

Documentation

237 | 238 |

The plugin API is quite simple and described above,but please take to your attention : 239 | Plugin provides maximum flexibility in implementing callback ,but also need to know when your callback logic is in in progress and when done in order to ignore additional onscroll events which can occur. 240 | Plugin has 2 approaches to accomplish that :

241 | 242 |
    243 |
  • Monitor the targetElement html and resume when changed.Enabled by default,you can disable it by providing : monitorTargetChange : false ,but then you need to use second approach.
  • 244 |
  • Callback function has parameter doneCallback which is passed to user code and you can just call it without any parameter to signal us you logic is done.
  • 245 |

Coming soon

246 | 247 |

Support for horizontal scroll

248 |
249 |