jQueryを使ってドラッグ&ドロップでオブジェクトの並び順を操作する
CMS操作時、登録したオブジェクトを並び替える際に順序を打ち込むのでも良いのですがドラッ…
TwitterやFacebookのように一番下までスクロールしたら自動的に追加データを読み込んで表示する機能を実装した時のソースをメモ。
サンプルはデータベース(Mysql)から10件づつデータを抽出。
<ul class="items">
<?php
require_once ('ini.php'); //DB接続ファイル
$sql = $db->query('SELECT * FROM tbl_sample ORDER BY id DESC LIMIT 10');
while($row = $sql->fetch(PDO::FETCH_ASSOC)){
echo('<li id="'.$row['id'].'">'.($row['name']).'</li>');
}
?>
</ul>
$(window).on('scroll', function(){
var doch = $(document).innerHeight(); //ページ全体の高さ
var winh = $(window).innerHeight(); //ウィンドウの高さ
var bottom = doch - winh; //ページ全体の高さ - ウィンドウの高さ = ページの最下部位置
if(bottom * 0.9 < $(window).scrollTop()){
var obj = $(this);
if (!obj.data('loading')) {
obj.data('loading', true);
$.get('loadmore.php', {lastid:$('ul.items li:last-of-type').attr('id')}, function(result){
$('ul.items').append(result);
obj.data('loading', false);
});
}
}
});
スクロール時のイベントの重複防止に、最初にイベントが発生した時点でのみobj.dataの「loading」をtrueに設定。
//追加読み込みの処理
require_once ('ini.php'); //DB接続ファイル
$lastid = $_GET['lastid'];
if(!empty($lastid)){
$sql = $db->prepare('SELECT * FROM tbl_sample WHERE id < :id ORDER BY id DESC LIMIT 10');
$sql->bindValue(':id', $lastid, PDO::PARAM_INT);
$sql->execute();
while($row = $sql->fetch(PDO::FETCH_ASSOC)){
echo('<li id="'.$row['id'].'">'.($row['name']).'</li>');
}
}
CMS操作時、登録したオブジェクトを並び替える際に順序を打ち込むのでも良いのですがドラッ…
ホームページ内に動画を設置する際にYouTubeを利用する場合は多い。YouTubeの埋…
YouTubeに掲載している動画の特定再生リストをサイト内に一覧表示したいという要望があ…