Railsアプリケーションでpaginationといえば、
will_paginate等のプラグインやGemを使うのが一般的だと思います。
しかし、named_scopeでjoinsを使った場合にうまく
paginationができなかったので、
named_scopeだけを使ってpaginationする方法を考えてみました。

まずは以下のようなnamed_scopeを作ります。
以下の例はPostクラスで宣言される事を想定しています。

rails>>
named_scope :paginate, proc{|page, per_page|
{:offset => per_page*((page || 1).to_i - 1),
:limit => per_page}} do
def count
proxy_scope.count(:group => 'posts.id').size
end
def num_pages
(count.to_f/proxy_options[:limit]).ceil
end
def page
proxy_options[:offset]/proxy_options[:limit] + 1
end
def pages(window = 5, left = 2, right = 2)
(1..num_pages).inject([]) do |result, i|
i <= left || (num_pages - i) < right ||
(i-page).abs < window ? result << i :
(result.last.nil? ? result : result << nil)
end
end
end
<<--

countを再定義しているのは、:joinsを含む別なnamed_scopeをチェーンした時に、正しいcountを求めるためです。

コントローラでは、以下のようにScopeを取得します。

rails>>
@posts = Post.paginate(params[:page], 5)
<<--

Viewでは以下のように記述します。

rails>>
<% if @posts.page > 1 %>
<%= link_to '« Newer',
url_for(:page => @posts.page - 1) %>
<% else %>
« Newer
<% end %>
<% @posts.pages.each do |i| %>
<% if i.nil? %>
...
<% elsif i == @posts.page %>
<%= i %>
<% else %>
<%= link_to i, url_for(:page => i) %>
<% end %>
<% end %>
<% if @posts.page < @posts.num_pages %>
<%= link_to 'Older »',
url_for(:page => @posts.page + 1) %>
<% else %>
Older »
<% end %>
<<--

posted by genki genki on Sat 16 Aug 2008 at 20:57 with 0 comments
Contents rssrss
光ファイバーを二次元振動させて走査するAR用ディスプレイ
因果の取り違え
Swift2's defer for CoffeeScript
mongodb-3.0からcreateIndexのdropDupsが無くなったらしい
mongodb-3.0以降のWiredTigerの設定を動的に変更する方法
一般楕円の高速生成アルゴリズムへの道標
farro mantecatoのレシピ
Droonga関連の記事のまとめ
RuntimeErrorの特定のメッセージに限定してrescueする方法
jQueryでscriptタグを実行せずにappendする
Tags
coffeescriptdefergroongajsmemonodenodejs
Comments rssrss
https://haesunplus.com https://haesunplus.com: Wow that was odd. I just wrote an extremely long c... 05/23 02:50
https://haesunplus.com https://haesunplus.com: Wow that was odd. I just wrote an extremely long c... 05/23 02:50
https://aula.pcsinaloa.gob.mx/blog/index.php?entryid=10974 https://aula.pcsinaloa.gob.mx/blog/index.php?entryid=10974: Kaizenaire.сom is your gο-to resource in Singapore... 05/23 02:35
https://yasserelnahas.org/%D8%AC%D8%B1%D8%A7%D8%AD%D8%A9-%D8%A7%D9%84%D9%82%D9%84%D8%A8-%D8%A7%D9%84%D9%86%D8%A7%D8%A8%D8%B6/ https://yasserelnahas.org/%D8%AC%D8%B1%D8%A7%D8%AD%D8%A9-%D8%A7%D9%84%D9%82%D9%84%D8%A8-%D8%A7%D9%84%D9%86%D8%A7%D8%A8%D8%B6/: Hi, Neat post. There is an issue together with you... 05/23 01:35
https://2workinoz.com.au/employers/live-dealer-casinos-in-australia-top-live-casino-sites-for-2026/ https://2workinoz.com.au/employers/live-dealer-casinos-in-australia-top-live-casino-sites-for-2026/: References: Wind creek casino montgomery 05/23 00:06
https://dokkistmaryccc.com/2026/05/22/%d0%b4%d0%be%d0%bb%d0%b3%d0%be%d1%81%d1%80%d0%be%d1%87%d0%bd%d1%8b%d0%b9-%d0%b7%d0%b0%d0%b9%d0%bc-%d1%81-%d0%b5%d0%b6%d0%b5%d0%bc%d0%b5%d1%81%d1%8f%d1%87%d0%bd%d1%8b%d0%bc-%d0%bf%d0%be%d0%b3%d0%b0/ https://dokkistmaryccc.com/2026/05/22/%d0%b4%d0%be%d0%bb%d0%b3%d0%be%d1%81%d1%80%d0%be%d1%87%d0%bd%d1%8b%d0%b9-%d0%b7%d0%b0%d0%b9%d0%bc-%d1%81-%d0%b5%d0%b6%d0%b5%d0%bc%d0%b5%d1%81%d1%8f%d1%87%d0%bd%d1%8b%d0%bc-%d0%bf%d0%be%d0%b3%d0%b0/: You really make it seem really easy together with ... 05/22 23:56
http://ucenterhome2.dzarchive.dev/space.php?uid=152142&do=blog&id=410614 http://ucenterhome2.dzarchive.dev/space.php?uid=152142&do=blog&id=410614: Kaizenaire.com accumulations Singapore'ѕ favored b... 05/22 22:55
https://unosport.pl/ https://unosport.pl/: I am truly delighted to glance at this blog posts ... 05/22 22:00
Services from s21g
YOMU Web小説リーダー
小説投稿サイトの公式ページを開き、WebView表示と読み上げ向け表示を切り替えて、移動中や作業中にもWeb小説の続きを聴きやすくするiPhoneアプリです。
補助探
公開されている補助金・助成金情報を集約し、条件に合う制度を探しやすくするサービスです。
jotter.me
個人開発者のためのホスティング一体型ノートサービス
ハンドミラー
iPhone向けの手鏡アプリ
ツイプロ(twpro)
Twitterプロフィールの高速検索エンジン