ruby-on-rails – Rails:通过Ajax渲染部分

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – Rails:通过Ajax渲染部分前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个带有选项卡的页面,我想在单击选项卡时通过ajax呈现不同的部分.我有一些代码,但我不认为这是最有效的方式.我希望是否有人可以帮助我使用已经存在的代码,或者如果有更简单的方法我会非常感激.谢谢!

HTML标签@H_403_3@

  1. <li class='StreamTab StreamTabRecent active'>
  2. <%= link_to 'Most Recent',mostrecent_schools_path,:remote => true,:class => 'TabText' %>
  3. </li>
  4.  
  5.  
  6. <div id='ContentBody'>
  7. <div id='ajax'></div>
  8. <%= render 'users/microposts',:microposts => @microposts %>
  9. </div>

学校管理员@H_403_3@

  1. class SchoolsController < ApplicationController
  2. def mostrecent
  3. @school = School.find_by_slug(request.url.gsub('http://localhost:3000/','')).id
  4. @microposts = @user.microposts.order('created_at DESC').paginate(:per_page => 3,:page => params[:page])
  5. respond_to do |format|
  6. format.html
  7. format.js
  8. end
  9. end
  10. end

最近的JS@H_403_3@

  1. $("#ContentBody").html('<%= escape_javascript(render :partial => "users/microposts" )%>');

路线@H_403_3@

  1. resources :schools do
  2. collection do
  3. get :mostrecent
  4. end
  5. end

解决方法

请参阅我之前的帖子的答案.这会给你一个想法 AJAX in Rails: Show model#new form after completing a model#update

你可以做的是在动作中渲染一个json并将部分传递给json.@H_403_3@

  1. def mostrecent
  2. @school = School.find_by_slug(request.url.gsub('http://localhost:3000/','')).id
  3. @microposts = @user.microposts.order('created_at DESC').paginate(:per_page => 3,:page => params[:page])
  4. respond_to do |format|
  5. format.json { render :json => {:success => true,:html => (render_to_string 'users/microposts')} }
  6. format.html { }
  7. end
  8. end

您可以访问js中的json(即javascript / coffeescript文件,例如mostrecent.js或mostrecent.js.coffee)并替换当前元素.@H_403_3@

  1. $('.TabText').live 'ajax:success',(event,data) ->
  2. $('#ContentBody').html(data.html) if(data.success == true)

猜你在找的Ruby相关文章