15

HTMLおよびJS(AJAX)クエリに応答するFooControllerがあります。

# app/controllers/foo_controller.rb:
class FooController < ApplicationController
  layout 'foo'
  def bar
    respond_to do |format|
      format.html # foo/bar.html.erb
      format.js   # foo/bar.js.erb
    end
  end
end

それをサポートするテンプレート:

# app/views/layouts/foo.html.erb:
<html>...<%= yield %>...</html>

# app/views/layouts/foo.json.erb:
<%= yield %>

そして、パーシャルをレンダリングしたいAJAXテンプレート:

# app/views/foo/bar.js.erb:
dojo.byID('some_div').innerHTML = "<%= escape_javascript(render(:partial => 'some/partial')) %>";

JSテンプレートに(のようにalert('hi');)単純な古いJSが含まれている場合は、私のJSテンプレートを使用します。ただし、render(:partial)を挿入すると、応答全体でHTMLテンプレートが使用されるため、有効なJSではなくなります。

考えられる解決策は、レイアウトに関数を使用することです。

class FooController < ApplicationController
  layout :choose_layout
  ...
  private
  def choose_layout
    return nil if request.xhr?
    'foo'
  end
end

しかし、私のバージョンは動作するはずです!なんでそうじゃないの?

4

2 に答える 2

8

最新のRailscastは、このトピックをカバーしています(jQueryを使用)

どこが間違っているのかよくわかりませんが、Railscastからの抜粋で、パーシャルをレンダリングするのに問題なく機能します。

// views/reviews/create.js.erb
$("#new_review").before('<div id="flash_notice"><%= escape_javascript(flash.delete(:notice)) %></div>');
$("#reviews_count").html("<%= pluralize(@review.product.reviews.count, 'Review') %>");
$("#reviews").append("<%= escape_javascript(render(:partial => @review)) %>");
$("#new_review")[0].reset();

Javascriptをどこに保存していますか?保持しているApplication.jsはありますか?もしそうなら、javascript_include_tagの「application」の前に「dojo」を含めていますか?

于 2008-11-19T13:30:51.120 に答える
1

以下を試してください。

class FooController < ApplicationController
  layout 'foo'
  def bar
    respond_to do |format|
      format.html
      format.js { render :layout => false }
    end
  end
end

それが役立つことを願っています。

JK

于 2009-02-22T03:35:44.920 に答える