Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to asynchronously load a partial page in rails

In creating a ruby on rails / jquery app, there's a part of a page that is time-consuming to generate.

I want to change how the page is loaded so that most of the page loads right away, and a placeholder is reserved for the time-consuming part to load asynchronously, and be injected into the page with ajax / jquery when it is finished.

What I have now (simplified):

app/views/sample/show.html.erb:

<div id="theResult">     <%= render :partial => 'calculate', :object => @org) %> </div> 

and the partial will use some parts @org to generate some content (hitting another external REST service).

app/views/sample/_calculate.html.erb

<%     # code to take org and turn it into content %> <!--...html to display results here --> 

I realize this is probably breaking proper MVC architecture rules since my partial seems to have too much logic, and would like to clean that up as well...

So I guess I have two questions in one: (1) how do I get this to work, and (2) how should I clean this up to follow good ruby/rails/mvc practices?

like image 844
Krease Avatar asked Jul 15 '11 00:07

Krease


1 Answers

First put an empty, placeholder div in the main response

<div id="pink-dancing-elephants"></div> 

and then add a little jQuery to the page

$.ajax({     url: "/elephants/dancing",     cache: false,     success: function(html){       $("#pink-dancing-elephants").append(html);     } }); 

and have the action that responses to /elephants/dancing/pink return the blob of HTML that you want to have fill up the div. In the action that is invoked by the AJAX request, you'll want to render with :layout => false to keep the returned blob of HTML from including the entire frame. E.g.

# elephants_controller.rb def dancing   @elephants = #whatever   render :layout => false end 

This would render the template in views/elephants/dancing.html.erb.

like image 165
cailinanne Avatar answered Oct 10 '22 22:10

cailinanne