JSONを介して画像を#photographsに読み込んでいます。最初に10ショットをロードし、特定のポイントまでスクロールダウンすると(ウェイポイントを使用して)、JSONフィードを「更新」して、追加の5ショットがロードされるようにする必要があります。これには、JSONURLで//&per_page ='+itemsLoaded//を使用しています。ウェイポイントがヒットするたびに+5で更新されるのはvaritemsLoadedです。
コードを参照してください:
var itemsLoaded = 10;
$.getJSON('http://api.flickr.com/services/rest/?format=json&method=flickr.photosets.getPhotos&photoset_id=' + photoset_id + '&per_page=' + itemsLoaded + '&page=1' + '&api_key=' + apiKey + '&user_id=' + userId + '&jsoncallback=?', function (data) {
$.each(data.photoset.photo, function (i, flickrPhoto) {
var basePhotoURL = 'http://farm' + flickrPhoto.farm + '.static.flickr.com/' + flickrPhoto.server + '/' + flickrPhoto.id + '_' + flickrPhoto.secret + "_b.jpg";
var basePhotoURLMobile = 'http://farm' + flickrPhoto.farm + '.static.flickr.com/' + flickrPhoto.server + '/' + flickrPhoto.id + '_' + flickrPhoto.secret + "_z.jpg";
var flickrLink = "http://www.flickr.com/photos/" + data.photoset.owner + "/" + flickrPhoto.id + "/";
var $img = $("<img/>").attr("src", basePhotoURL);
var $imgMobile = $("<img/>").attr("src", basePhotoURLMobile);
var $wrap = $("<div class='item'></div>");
$(".item:nth-child(9n)").addClass("tenth");
if($(window).width() < 501) {
$wrap.append($imgMobile);
} else {
$wrap.append($img);
}
$wrap.append("<a href='" + basePhotoURL + "'.jpg' title='View full size' class='zoom' rel='enroll' />");
$wrap.append("<a href='" + flickrLink + "' class='flickr' title='View on Flickr' target='_blank' />");
$wrap.appendTo('#photographs');
});
var loaded = 0;
var totalAmount = $('#photographs .item').length;
$('#photographs .item img').each(function() {
loaded;
$(this).imagesLoaded(function($images) {
loaded++;
var percentage = parseInt((loaded / 11) * 100);
console.log(loaded + ' van de ' + totalAmount);
$("#bigloader").progressbar({
value: percentage
});
if(loaded == 10) {
$("#photographs, #loader").fadeIn("fast");
$("#bigloader, #preloading").fadeOut("fast");
$("#photographs").gridalicious({
gutter: 2,
animate: true,
effect: 'fadeInOnAppear',
width: 430
});
$('.item.tenth').waypoint({
triggerOnce: true,
handler: function(){
console.log("arrived at trigger");
itemsLoaded = itemsLoaded + 5;
},
offset: '50%'
});
} else if (loaded == totalAmount) {
$("#loader").fadeOut("fast");
};
});
});
追加の説明:
itemsLoaded変数は、ウェイポイントがヒットするたびに+5値で更新されます。itemsLoadedは、JSONを介して読み込まれるアイテムの数の鍵です。そのため、JSONフィードを更新する必要があります。
基本的に、既存のJSONフィードを更新された変数で更新するにはどうすればよいですか?