Я новачок у rails та jQuery. У мене є дві окремі форми на одній сторінці, і я хочу подати їх окремо ajax (за допомогою jQuery). Ось як далеко я дійшов. Хтось може додати або виправити цей код, щоб він працював. Я використовую Rails 3.1 та jQuery 1.6. Спасибі заздалегідь.
application.js
$(".savebutton").click(function() {
$('form').submit(function() {
$(this).serialize();
});
});
перша форма:
<%=form_for :users do |f| %>
<fieldset>
<legend>Basic details</legend>
<%= f.label :school %>
<%= f.text_field :school,:size=>"45",:class=>"round",:id=>"school" %><br/>
</fieldset>
<p><%= button_to "save and continue",{:class=>"savebutton"} %></p>
<%end%>
друга форма:
<%=form_for :courses do |c| %>
<fieldset>
<legend>Your current classes</legend>
<label>class:</label><%= c.text_field :subject,:size=>"45",:class=>"round" %><br/>
</fieldset>
<p><%= button_to "save and continue",{:class=>"savebutton"} %></p>
<%end%>
SchoolController
class SchoolController < ApplicationController
respond_to :json
def create
@school = current_user.posts.build(params[:school].merge(:user => current_user))
if @school.save
respond_with @school
else
respond_with @school.errors, :status => :unprocessable_entity
end
end
end
CourseController має таку ж форму, що і SchoolController
routes.rb
, вам потрібно переконатися, що ви використовуєте POST, а не GET. За допомогою jQuery просто додайтеtype: 'POST'
до$.ajax
дзвінка.