Git Product home page Git Product logo

nested_layout's Introduction

#nested_layout

This project use nested layout

static_page use layout named "user_layout" product use layout named "product_layout" user_layout and product_layout use base_layout ##Controller

In app/controllers/static_pages_controller.rb

class StaticPagesController < ApplicationController                                                                                                                
  layout "user_layout"                                                          
  def index                                                                     
  end                                                                           
end 

In app/controllers/products_controller.rb

class ProductsController < ApplicationController                                                                                                                                                                  
  layout "product_layout"                                                          
  def index                                                                   
  end                                                                           
end

##View (important)

  1. Create new partial file named "base_layout.html.erb" and put it in app/views/layout with content:
<!DOCTYPE html>                                                                 
<html lang="ja">                                                                
  <head>                                                                        
    <meta charset="utf-8">                                                      
    <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">              
    <meta name="viewport" content="width=device-width, initial-scale=1.0">      
    <%= yield(:metatag) if content_for?(:metatag) %>                            
    <title>Nested Layouts</title>                                               
    <%= csrf_meta_tags %>                                                       
                                                                                
  </head>                                                                       
  <body>                                                                        
    <%= content_for?(:content) ? yield(:content) : yield %>                     
    <%= yield(:bottom) if content_for?(:bottom) %>                              
  </body>                                                                       
</html>
  1. Create 2 index files in app/views/static_pages and app/views/products
  2. Put some text in that 2 file in
<% content_for(:content) do %>
  This is in static page
<% end %>

and

  <% content_for(:content) do %>
    This is in product page
  <% end %>

Not only :content, you can use whatever you defined in app/views/layout/_base_layout

This technique is called nested layout. It's can DRY your code in views and make your application more reasonable.

nested_layout's People

Watchers

James Cloos avatar Bui Trung Kien avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.