PJAX for Rails 3.1+
Integrate Chris Wanstrath's PJAX into Rails 3.1+ via the asset pipeline.
To activate, add this to your app/assets/javascripts/application.js (or whatever bundle you use):
//=require pjax
All links that match $('a:not([data-remote]):not([data-behavior]):not([data-skip-pjax])')
will then use PJAX.
The PJAX container has to be marked with data-pjax-container attribute, so for example:
<body>
<div>
<!-- This will not be touched on PJAX updates -->
<%= Time.now %>
</div>
<div data-pjax-container>
<!-- PJAX updates will go here -->
<%= content_tag :h3, 'My site' %>
<%= link_to 'About me', about_me_path %>
<!-- The following link will not be pjax'd -->
<%= link_to 'Google', 'http://google.com', 'data-skip-pjax' => true %>
</div>
</body>
FIXME: Currently the layout is hardcoded to "application". Need to delegate that to the specific layout of the controller.
Examples for redirect_pjax_to
class ProjectsController < ApplicationController
before_filter :set_project, except: [ :index, :create ]
def index
@projects = current_user.projects
end
def show
end
def create
@project = Project.create params[:project]
redirect_pjax_to :show, @project
end
def update
@project.update_attributes params[:project]
redirect_pjax_to :show, @project
end
def destroy
@project.destroy
index # set the objects needed for rendering index
redirect_pjax_to :index
end
private
def set_project
@project = current_user.projects.find params[:id].to_i
end
end