最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Unable to bind ajax:success to form created with form_for .... :remote => true - Stack Overflow

programmeradmin2浏览0评论

I'm using Rails 3.1.1

I have the following in a haml view:

= form_for booking.notes.build, :remote => true do |f|
  = f.text_area(:content)
  = f.hidden_field(:noteable_id)
  = f.hidden_field(:noteable_type)
  = f.submit('Add note')

Which creates new notes on submission. Also the response from my controller is appearing correctly in a Chrome console (Network tab). But I cannot seem to grab the response.

I want to update the note list on the page after submission. I've been trying to bind to the ajax response so I can grab the response, but I am failing. For example, I think this should work but does not:

$('#new_note').bind('ajax:success', function() {
  alert('Hi');
});

But no alert is triggered. Which I think explains why this also doesn't work.

 $('#new_note').bind("ajax:success", function(evt, data, status, xhr){
  // Insert response partial into page below the form.
  $(this).parent.append(xhr.responseText);

})

Can you please point me as to what might be going wrong?

I'm using Rails 3.1.1

I have the following in a haml view:

= form_for booking.notes.build, :remote => true do |f|
  = f.text_area(:content)
  = f.hidden_field(:noteable_id)
  = f.hidden_field(:noteable_type)
  = f.submit('Add note')

Which creates new notes on submission. Also the response from my controller is appearing correctly in a Chrome console (Network tab). But I cannot seem to grab the response.

I want to update the note list on the page after submission. I've been trying to bind to the ajax response so I can grab the response, but I am failing. For example, I think this should work but does not:

$('#new_note').bind('ajax:success', function() {
  alert('Hi');
});

But no alert is triggered. Which I think explains why this also doesn't work.

 $('#new_note').bind("ajax:success", function(evt, data, status, xhr){
  // Insert response partial into page below the form.
  $(this).parent.append(xhr.responseText);

})

Can you please point me as to what might be going wrong?

Share Improve this question asked Mar 16, 2012 at 15:23 ReggieBReggieB 8,2573 gold badges42 silver badges48 bronze badges 1
  • I've got around this by using a create.js.erb with code that updates the necessary object. But I'd rather be able to grab the ajax call, so that I can use the ajax error object if necessary. – ReggieB Commented Mar 16, 2012 at 15:54
Add a ment  | 

3 Answers 3

Reset to default 9

Did you try 'ajax:plete'?

Other things that can go wrong here:

Status code was not really "successful". This triggers success in jQuery

if ( status >= 200 && status < 300 || status === 304 ) {

Or the event handler was evaluated before the form was rendered. Try event delegation:

$("body").on('ajax:success', '#new_note', function(){...})

(careful, this is the new jQuery syntax. If using old jQuery, adjust accordingly)

if you want, you can put your javascript in create.js.erb (code in this file will be executed after response will e to your browser) And in this file you can use if statement, like

<% if @ok %>
  //your code
<% end %>

if in your controller's action set @ok to false the response will be empty!

This is generally done by doing a create.js.erb file in your controller's view section (if haven't done so already) in which you have access to whatever variables e out of the create action, and there you can render your html

in your create.js.erb file you could write something like

$("#new_note").html('<%= escape_javascript(render partial: "path/to/partial") %>');

read more in this post I wrote some time ago, it pretty much explains the whole flow

发布评论

评论列表(0)

  1. 暂无评论