Простой пример Rails 3 + UJS с использованием Ajax для удаленного вызова и рендеринга полученного объекта JSON

Я пытаюсь добавить некоторые функции Ajax в мое приложение Rails 3.

В частности, я хочу кнопку, которая будет отправлять запрос Ajax для вызова удаленной функции в моем контроллере, которая впоследствии запрашивает API и возвращает объект JSON на страницу.

Как только я получаю объект JSON, я хочу отобразить содержимое.

Все это с новым подходом Rails 3 UJS. Есть ли хороший пример/учебник для этого онлайн где-то? Я не смог найти его в google. Простой пример с использованием кнопки в качестве точки входа (то есть, пользователь нажимает кнопку для запуска этого процесса) тоже будет работать.

Edit Позвольте мне попробовать это с другим подходом. Я хочу, чтобы эта кнопка запрашивала внешний API, который возвращает JSON и отображает этот JSON на странице. Я понятия не имею, с чего начать. Сама ли кнопка запрашивает внешний API? Нужно ли мне проходить через контроллер и запросить контроллер внешнего API, получить JSON и вернуть JSON на эту страницу? Как отобразить/получить доступ к содержимому этого JSON? Я честно не могу найти хороший Rails 3.x пример того, как обращаться с JSON...

Ответ 1

Вот начало:

Сначала создайте свою кнопку с помощью метода link_to в вашем представлении, например:

=link_to "delete", "#{invitation_path(invitation)}.json", :method=>:delete, :remote=>true, :class=>"remove", :confirm=>'Are you sure you?'

Обратите внимание, что я добавляю ".json" к URL-адресу моего ресурса. Это просто пример удаления AJAX, google link_to, чтобы увидеть значение параметров. Понятие, если вы делаете свой HTTP-запрос с параметром: remote set to true, другими словами, это переводится на вызов AJAX из вашего браузера.

Во-вторых, напишите javascript, чтобы вы могли обработать то, что когда-либо было результатом вызова AJAX, который ваш браузер сделает, когда пользователь нажмет на ссылку_ на шаге 1. Подробнее вы можете увидеть это сообщение в блоге: http://www.alfajango.com/blog/rails-3-remote-links-and-forms/

Пример моего сайта:

jQuery(function($) {
  // create a convenient toggleLoading function
  var toggleLoading = function() { $("#loading").toggle() };

  $("#pending_invitation")
    .live("ajax:loading",  toggleLoading)
    .live("ajax:complete", toggleLoading)
    .live("ajax:success", function(event, data, status, xhr) {
       var response = JSON.parse(xhr.responseText)
       if (response.result == "ok") {
          $(this).fadeOut('fast');
       }
       else {
         var errors = $('<div id="error_explanation"/>');
         errors.append('<h2>Pending invitation action error</h2><ul><li>' + response.error + '</li></ul>');
         $('#new_invitation_error').append(errors)   
       }
    });
});

где вы можете увидеть, что я разбираю возвращаемый json и изменяю html на странице на основе этого. Обратите внимание, что этот js использует идентификаторы и классы CCS, определенные в верхнем представлении, которые здесь не включены.

Если вы сейчас хотите написать собственный контроллер, чтобы выплюнуть json, вот пример:

class InvitationsController < ApplicationController
  respond_to :html, :json

  # other methods here
  # ...

  def destroy
    @invitation = Invitation.find(params[:id])
    respond_to do |format|
      if @invitation
        @invitation.destroy
        flash[:success] = I18n.t 'invitations.destroy.success'
        format.json { render :json =>{:result => "ok", :message=>"Invitation #{params[:id]} was destroyed", :resource_id=>params[:id] } }
      else
        format.json { render :json => { :result=>"failed", :error=>"Cannot find Invitation #{params[:id]}", :resource_id=>params[:id] } }
      end
    end
  end
end

Надеюсь на эту помощь.

Ответ 3

Также рассмотрите возвращаемые ошибки в следующем формате:

render :json => @myobject.to_json, :status => :unprocessable_entity

Это гарантирует, что ваш клиент сможет обработать ответ как ошибку.