Module: AbstractController::Rendering
- Extended by:
 - ActiveSupport::Concern
 
- Includes:
 - ActionView::ViewPaths
 
- Included in:
 - ActionController::Base, ActionMailer::Base
 
- Defined in:
 - actionpack/lib/abstract_controller/rendering.rb
 
Constant Summary collapse
- DEFAULT_PROTECTED_INSTANCE_VARIABLES =
 %i(@_action_name @_response_body @_formats @_prefixes)
Instance Method Summary collapse
- 
  
    
      #render(*args, &block)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Normalizes arguments and options, and then delegates to render_to_body and sticks the result in ‘self.response_body`.
 - 
  
    
      #render_to_body(options = {})  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Performs the actual template rendering.
 - 
  
    
      #render_to_string(*args, &block)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Similar to #render, but only returns the rendered template as a string, instead of setting ‘self.response_body`.
 - 
  
    
      #rendered_format  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Returns ‘Content-Type` of rendered content.
 - 
  
    
      #view_assigns  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
This method should return a hash with assigns.
 
Methods included from ActiveSupport::Concern
append_features, class_methods, extended, included, prepend_features, prepended
Methods included from ActionView::ViewPaths
#_prefixes, #append_view_path, #details_for_lookup, #lookup_context, #prepend_view_path
Instance Method Details
#render(*args, &block) ⇒ Object
Normalizes arguments and options, and then delegates to render_to_body and sticks the result in ‘self.response_body`.
Supported options depend on the underlying ‘render_to_body` implementation.
      26 27 28 29 30 31 32 33 34 35 36  | 
    
      # File 'actionpack/lib/abstract_controller/rendering.rb', line 26 def render(*args, &block) = _normalize_render(*args, &block) rendered_body = render_to_body() if [:html] _set_html_content_type else _set_rendered_content_type rendered_format end _set_vary_header self.response_body = rendered_body end  | 
  
#render_to_body(options = {}) ⇒ Object
Performs the actual template rendering.
      50 51  | 
    
      # File 'actionpack/lib/abstract_controller/rendering.rb', line 50 def render_to_body( = {}) end  | 
  
#render_to_string(*args, &block) ⇒ Object
Similar to #render, but only returns the rendered template as a string, instead of setting ‘self.response_body`.
If a component extends the semantics of ‘response_body` (as ActionController extends it to be anything that responds to the method each), this method needs to be overridden in order to still return a string.
      44 45 46 47  | 
    
      # File 'actionpack/lib/abstract_controller/rendering.rb', line 44 def render_to_string(*args, &block) = _normalize_render(*args, &block) render_to_body() end  | 
  
#rendered_format ⇒ Object
Returns ‘Content-Type` of rendered content.
      54 55 56  | 
    
      # File 'actionpack/lib/abstract_controller/rendering.rb', line 54 def rendered_format Mime[:text] end  | 
  
#view_assigns ⇒ Object
This method should return a hash with assigns. You can overwrite this configuration per controller.
      62 63 64 65 66 67 68  | 
    
      # File 'actionpack/lib/abstract_controller/rendering.rb', line 62 def view_assigns variables = instance_variables - _protected_ivars variables.each_with_object({}) do |name, hash| hash[name.slice(1, name.length)] = instance_variable_get(name) end end  |