Ich bin ein Anfänger in Rails und jQuery. Ich habe zwei separate Formulare auf einer Seite und möchte sie separat auf Ajax-Weise (mit jQuery) einreichen. So weit bin ich gekommen. Kann jemand diesen Code hinzufügen oder korrigieren, damit er funktioniert? Ich verwende Rails 3.1 und jQuery 1.6. Danke im Voraus.
application.js
$(".savebutton").click(function() {
$('form').submit(function() {
$(this).serialize();
});
});
erste Form:
<%=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%>
zweite Form:
<%=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 hat die gleiche Form wie SchoolController
routes.rb
, müssen Sie sicherstellen, dass Sie einen POST und keinen GET verwenden. Fügen Sie mit jQuery einfach hinzutype: 'POST'
dem$.ajax
Aufruf hinzu.