gem 'kaminari'
gemfileに上記のコードを書き、bundle install
を使ってインストールします。
ページネーションを実装したいモデルのコントローラで、データを取得するメソッドを作成します。例えば、indexアクション内でデータを取得する場合は以下のコードにします。
def index
@shops = Kaminari.paginate_array([]).page(params[:page]).per(10)
end
これにより、shopモデルからデータを取得し、pageメソッドでページ番号を指定し、perメソッドで1ページあたりのshop数を指定しています。このコードの場合は1ページに10個の店のを表示します。
次にconfig/initializers/kaminari_config.rb
ファイルを作成し、以下のように設定します。
Kaminari.configure do |config|
config.default_per_page = 10
end
ビューファイルにページネーションリンクを表示する場合は以下のコードを記載したいファイルに書き加えます。
<%= paginate @shops %>
これにより、@shopsのページネーションリンクが表示されます。
また、ページネーションのスタイルを変える場合はpplication.css
にコードを書くことで変更が出来ます。
/* application.css */
.pagination-container {
display: flex;
justify-content: center;
margin-top: 20px; /* 必要に応じて適切なマージンを指定してください */
}
/* application.scss */
.pagination-container {
display: flex;
justify-content: center;
margin-top: 20px; /* 必要に応じて適切なマージンを指定してください */
}