我在一个新的rails 3应用程序中收到了我的第一个远程表单,但我无法让它远程提交:它一直以html形式提交。我在其他rails 3应用程序中也做过这件事,所以我想这一定是我忘记的事情。
这是我在html.erb文件中的表格:
<%= form_for Assignment.new, :remote => true do |f| %>
<%= hidden_field_tag "assignment[task_id]", @task.id %>
<%= hidden_field_tag "assignment[person_id]", person.id %>
<%= submit_tag "Add to task" %>
<% end %>
下面是它在页面上的表现。我已经包含了javascript文件链接,因为我觉得这个问题与js设置不正确有关。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<script src="/javascripts/jquery.js?1306857355" type="text/javascript"></script>
<script src="/javascripts/person.js?1306857355" type="text/javascript"></script>
<script src="/javascripts/jquery-ui-1.8.11.custom.min.js?1306857355" type="text/javascript"></script>
<script src="/javascripts/jquery_ujs.js?1306857355" type="text/javascript"></script>
<script src="/javascripts/jquery.ui.datepicker.js?1306857355" type="text/javascript"></script>
<script src="/javascripts/jquery.colorbox-min.js?1306857355" type="text/javascript"></script>
<script src="/javascripts/jquery.tipTip.minified.js?1306857355" type="text/javascript"></script>
<script src="/javascripts/application.js?1306857355" type="text/javascript"></script>
<meta name="csrf-param" content="authenticity_token"/>
<meta name="csrf-token" content="ErI0bMA1E0JAXwvyVMistPsWc4fg2dG5tDPOgeur358="/>
</head>
<body class="tasks">
<form accept-charset="UTF-8" action="/assignments" class="new_assignment" data-remote="true" id="new_assignment" method="post">
<div style="margin:0;padding:0;display:inline">
<input name="utf8" type="hidden" value="✓" />
<input name="authenticity_token" type="hidden" value="ErI0bMA1E0JAXwvyVMistPsWc4fg2dG5tDPOgeur358=" />
</div>
<input id="assignment_task_id" name="assignment[task_id]" type="hidden" value="2" />
<input id="assignment_person_id" name="assignment[person_id]" type="hidden" value="1" />
<input name="commit" type="submit" value="Add to task" />
</form>
</body>
</html>
这一切看起来都设置得很好。但是,当我提交时,我在日志中完成了这一点:
Started POST "/tasks/2" for 127.0.0.1 at 2011-06-08 15:56:42 +0100
Processing by TasksController#update as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"ErI0bMA1E0JAXwvyVMistPsWc4fg2dG5tDPOgeur358=", "assignment"=>{"task_id"=>"2", "person_id"=>"1"}, "commit"=>"Add to task", "id"=>"2"}
就像我说的,我想我只是错过了一些我需要做的事情,以正确地连接起来。这也是我的Gemfile,以防相关:
source 'http://rubygems.org'
gem "rake", "0.8.7"
gem 'rails', '3.0.7'
gem 'haml'
gem 'heroku'
gem "heroku_backup_task"
gem 'authlogic', '3.0.2'
gem 'rails3-generators'
gem 'txtlocal', :git => 'git://github.com/epigenesys/txtlocal.git'
gem 'chronic'
gem 'sqlite3-ruby', :require => 'sqlite3'
gem 'bcrypt-ruby'
gem 'taps' #for heroku db import/export
gem 'jquery-rails', '>= 1.0.3'
gem 'jrails'
group :development, :test do
gem 'rspec'
gem 'mocha'
gem "rspec-rails", "~> 2.4"
gem 'database_cleaner', '0.5.2'
gem 'capybara', :git => 'git://github.com/jnicklas/capybara.git'
gem 'selenium-client'
gem 'machinist'
gem 'faker'
end
有人能看到缺了什么吗
谢谢,最大
编辑-我犯了一个愚蠢的错误:包含远程表单的分部被从另一个调用相同操作的非远程表单内部调用。因此,外部表单是由提交按钮触发的,而不是内部远程按钮。Doh。感谢阅读。
我遇到了同样的问题,我通过在路径中添加:format=>:js解决了这个问题。
所以它看起来像这样:
<%= form_for :assignment, :url => assignments_path(:format => :js)
我也遇到过这种情况,尽管原因不同。在我的情况下,这是由于我使用了form_tag
而不是form_for
。后者显然添加了适当的params,使调用通过Ajax。