Интересно, может ли кто-нибудь рассказать мне, если will_paginate может поддерживать JSON из коробки или если это нужно взломать?
Я хотел бы добавить данные страницы в ответы JSON, а will_paginate - управлять разбиением на страницы.
Интересно, может ли кто-нибудь рассказать мне, если will_paginate может поддерживать JSON из коробки или если это нужно взломать?
Я хотел бы добавить данные страницы в ответы JSON, а will_paginate - управлять разбиением на страницы.
Что-то в строках:
@posts = Post.paginate :page => params[:page]
respond_to do |format|
format.json {
render :json => {
:current_page => @posts.current_page,
:per_page => @posts.per_page,
:total_entries => @posts.total_entries,
:entries => @posts
}
}
end
Как только вы выясните, какой формат вы хотите, вы всегда можете определить метод to_json
в коллекции WillPaginate:: Collection.
Добавление разбивки на страницы в API
Я нашел легкое решение для разбиения на API Json Response Pagination с will_pagination.
начните с создания метода класса в ApplicationController
, который создаст after_filter
, который установит метаданные разбиения на страницы в заголовках ответов:
application_controller.rb
class ApplicationController < ActionController::Base
protected
def self.set_pagination_headers(name, options = {})
after_filter(options) do |controller|
results = instance_variable_get("@#{name}")
headers["X-Pagination"] = {
total: results.total_entries,
total_pages: results.total_pages,
first_page: results.current_page == 1,
last_page: results.next_page.blank?,
previous_page: results.previous_page,
next_page: results.next_page,
out_of_bounds: results.out_of_bounds?,
offset: results.offset
}.to_json
end
end
end
Затем в контроллере мы хотим добавить заголовки разбиения на страницы, которые мы можем назвать так:
widgets_controller.rb
class Api::V1::WidgetsController < Api::V1::BaseController
set_pagination_headers :widgets, only: [:index]
def index
@widgets = Widget.all.paginate(params).order("created_at desc")
respond_with @widgets
end
end
заголовки ответов, которые выглядят следующим образом
> Cache-Control:max-age=0, private, must-revalidate
> Connection:keep-alive Content-Type:application/json; charset=utf-8
> Etag:"fe70f7bae4c6e5cdea7867aa7fc0c7b4"
> X-Pagination:{"total":14,"total_pages":1,"first_page":true,"last_page":true,"previous_page":null,"next_page":null,"out_of_bounds":false,"offset":0}
> Server:thin 1.3.1 codename Triple Espresso
> Set-Cookie:_widgets_session=BAh7CEkiD3Nlc3Npb25faWQGOgZFRkkiJTAzYjVlNzkwZTIyNzU4YTYwMDU0M2MwOTQ2ZWI3YWU2BjsAVEkiDWxhc3RfdXJsBjsARkkiM2h0dHA6Ly9tYWluYW5kbWUtc3RhZ2luZy5oZXJva3VhcHAuY29tL3VzZXJzLzEGOwBGSSIQX2NzcmZfdG9rZW4GOwBGSSIxdjd0SEp6cVhKamh5YTh1cnBUdmpBb0w5aVA0bS9QTEdON3g1UlFUYnBkND0GOwBG--71b3a24c216a414d8db04f312b5300c818e6bba4;
> path=/; HttpOnly Transfer-Encoding:Identity
> X-Request-Id:61b383ade49cba8b24a715a453ed6e1f X-Runtime:0.191485
> X-Ua-Compatible:IE=Edge,chrome=1
Самое легкое решение
def index
@posts = Post.all.paginate(:page => params[:page], :per_page => 4)
render :json => @posts.to_json(:methods => [:image_url])
end
вам просто нужно добавить gem, will_pagination
он работает для меня
will_paginate просто возвращает записи нарезанным образом. Таким образом, он просто получает массив из вашей базы данных.
Когда вы выполняете рендеринг как json, эти рельсы переходят через массив объектов и вызывают as_json на них.
Итак, да, вы можете выставить визуализацию в виде json.
Я рекомендую вам посмотреть этот Railscast: Разбиение страницы с помощью AJAX
Это помогает мне:
https://github.com/rails-api/active_model_serializers/blob/master/docs/howto/add_pagination_links.md
Адаптированные:
Добавьте этот метод к базовому API-интерфейсу.
def pagination_dict(collection)
{
current_page: collection.current_page,
next_page: collection.next_page,
prev_page: collection.prev_page, # use collection.previous_page when using will_paginate
total_pages: collection.total_pages,
total_count: collection.total_count # use collection.total_entries when using will_paginate
}
end
Затем используйте его в методе рендеринга.
render json: posts, meta: pagination_dict(posts)