2007-07-29Rails宝典之第七式: layout详解

 关键字: Rails layout

这次的视频很有用,详细解释了layout的用法

一般来说layout有如下五种:

gobal layout,controller layout,shared layout,dynamic layout,action layout

假设我们有一个views/projects/index.rhtml页面:

Java代码

 

  1. <h2>Projects</h2>   
  2. <ul>   
  3. <% for project in @projects %>   
  4.   <li><%= project.name %></li>   
  5. <% end %>   
  6. </ul>  

 

<h2>Projects</h2><ul><% for project in @projects %> <li><%= project.name %></li><% end %></ul>

下面来看看各种layout的用法。

1,global layout

添加views/layouts/application.rhtml:

Java代码

 

  1. <h1>Application Layout!</h1>   
  2. <%= yield %>  

 

<h1>Application Layout!</h1><%= yield %>

在layouts目录下添加application.rhtml即可,<%= yield %>即输出我们的projects/index.rhtml页面

由于我们的controller都继承自ApplicationController,所以application.rhtml会先解析

2,controller layout

添加views/layouts/projects.rhtml:

Java代码

 

  1. <h1>Projects Layout!</h1>   
  2. <%= yield %>  

 

<h1>Projects Layout!</h1><%= yield %>

道理同上,ProjectsController当然会使用同名的projects.rhtml作layout了

注意的是controller layout会覆盖global layout

3,shared layout

添加views/layouts/admin.rhtml:

Java代码

 

  1. <h1>Admin Layout!</h1>   
  2. <%= yield %>  

 

<h1>Admin Layout!</h1><%= yield %>

我们建立了admin layout,然后在需要使用该layout的controller中指定即可:

Java代码

 

  1. class ProjectsController < ApplicationController   
  2.   layout "admin"  
  3.   
  4.   def index    
  5.     @projects = Project.find(:all)   
  6.   end   
  7. end  

 

class ProjectsController < ApplicationController layout "admin" def index @projects = Project.find(:all) endend

4,dynamic layout

有时候我们需要根据不同的用户角色来使用不同的layout,比如管理员和一般用户,比如博客换肤(也可以用更高级的theme-generator)

Java代码

 

  1. class ProjectsController < ApplicationController   
  2.   layout :user_layout   
  3.   
  4.   def index   
  5.     @projects = Project.find(:all)   
  6.   end   
  7.   
  8.   protected  
  9.   
  10.   def user_layout   
  11.     if current_user.admin?   
  12.       "admin"  
  13.     else  
  14.       "application"  
  15.     end   
  16.   end   
  17. end  

 

class ProjectsController < ApplicationController layout :user_layout def index @projects = Project.find(:all) end protected def user_layout if current_user.admin? "admin" else "application" end endend

5,action layout

在action中指定layout即可:

Java代码

 

  1. class ProjectsController < ApplicationController   
  2.   layout :user_layout   
  3.   
  4.   def index   
  5.     @projects = Project.find(:all)   
  6.     render :layout => 'projects'  
  7.   end   
  8.   
  9.   protected  
  10.   
  11.   def user_layout   
  12.     if current_user.admin?   
  13.       "admin"  
  14.     else  
  15.       "application"  
  16.     end   
  17.   end   
  18. end  

 

class ProjectsController < ApplicationController layout :user_layout def index @projects = Project.find(:all) render :layout => 'projects' end protected def user_layout if current_user.admin? "admin" else "application" end endend

上面的index方法指定使用projects layout,当然我们也可以指定不使用layout,如printable页面:

Java代码

 

  1. def index   
  2.   @projects = Project.find(:all)   
  3.   render :layout => false  
  4. end  

 

def index @projects = Project.find(:all) render :layout => falseend

需要注意的是,这5种layout会按顺序后面的覆盖前面的layout

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值