一般来说layout有如下五种:
gobal layout,controller layout,shared layout,dynamic layout,action layout
假设我们有一个views/projects/index.rhtml页面:
代码
1. <h2>Projects</h2>
2. <ul>
3. <% for project in @projects %>
4. <li><%= project.name %></li>
5. <% end %>
6. </ul>
下面来看看各种layout的用法。
1,global layout
添加views/layouts/application.rhtml:
代码
1. <h1>Application Layout!</h1>
2. <%= yield %>
在layouts目录下添加application.rhtml即可,<%= yield %>即输出我们的projects/index.rhtml页面
由于我们的controller都继承自ApplicationController,所以application.rhtml会先解析
2,controller layout
添加views/layouts/projects.rhtml:
代码
1. <h1>Projects Layout!</h1>
2. <%= yield %>
道理同上,ProjectsController当然会使用同名的projects.rhtml作layout了
注意的是controller layout会覆盖global layout
3,shared layout
添加views/layouts/admin.rhtml:
代码
1. <h1>Admin Layout!</h1>
2. <%= yield %>
我们建立了admin layout,然后在需要使用该layout的controller中指定即可:
代码
1. class ProjectsController < ApplicationController
2. layout "admin"
3.
4. def index
5. @projects = Project.find(:all)
6. end
7. end
4,dynamic layout
有时候我们需要根据不同的用户角色来使用不同的layout,比如管理员和一般用户,比如博客换肤(也可以用更高级的theme-generator)
代码
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
5,action layout
在action中指定layout即可:
代码
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
上面的index方法指定使用projects layout,当然我们也可以指定不使用layout,如printable页面:
代码
1. def index
2. @projects = Project.find(:all)
3. render :layout => false
4. end
需要注意的是,这5种layout会按顺序后面的覆盖前面的layout
分享到:
相关推荐
布局组件EasyUI Layout使用方法详解首先介绍了该组件的基本概念和重要性。对于Web开发人员来说,界面布局通常是一个比较繁琐的任务,特别是对于那些不擅长美工设计的程序员来说,EasyUI Layout能够提供一个简单快捷...
justified-layout, 通过长方体大小并获取合理布局的尺寸和坐标 与flickr布局对齐 通过框大小并回收大小和坐标,如在Flickr上看到的一个好的合理布局。 探索页面是一个很好的例子。 下面是另一个使用 ...
该指导详细介绍了射频LAYOUT的设计原则、实现方法和参数配置,旨在帮助客户快速掌握射频LAYOUT的使用和设计。 射频LAYOUT的重要性 射频LAYOUT是4G模块天线中最重要的组件之一,它直接影响着天线的性能和稳定性。...
本文将深入探讨Sprint-Layout60的核心功能、使用方法以及它如何帮助开发者优化项目。 首先,Sprint-Layout60的主要功能在于提供一套完善的布局解决方案,适用于各种复杂的界面设计需求。它包含了丰富的组件库,这些...
三、使用方法 1. **引入插件**:在HTML文件中通过`<script>`标签引入layout.js库,可以使用CDN链接或者本地文件路径。 2. **定义布局**:使用JavaScript代码或者数据属性来定义元素的布局属性,如宽度、高度、间隔...
由于HFSS 3D Layout是基于HFSS开发的,因此对于那些已经有HFSS使用经验的工程师来说,他们可以轻松地将HFSS 3D Layout项目导出为HFSS项目,从而利用HFSS的强大功能进行更深入的仿真分析。 HFSS 3D Layout用户手册...
使用 Vue 实现 Grid Layout 功能实例代码 本文主要介绍了使用 Vue 实现 Grid Layout 功能的代码讲解,涵盖了基本布局、节点排版、拖拽事件等多个方面的知识点。 基本布局 在实现 Grid Layout 功能之前,首先需要 ...
本文将深入探讨jQuery Layout的使用方法和关键特性。 首先,我们需要理解jQuery Layout的基本结构。在经典的“东南西北中”布局中,页面被划分为五个区域:北(North)、南(South)、东(East)、西(West)和中心...
使用`View.measure()`和`View.layout()`方法进行测量和布局。如果不进行这些步骤,新添加的视图可能不会显示或者位置不正确。 3. **响应事件** 动态创建的视图同样可以注册监听器,以便在用户交互时执行相应的操作...
Android Layout多种使用方法源码演示,这个例子中演示了如何使用FrameLayout、如何使用RelativeLayout、如何使用RelativeLayout和LinearLayout以及如何使用TableLayout的例子,都挺实用,平时用的比较多,但是比较...
以上知识点总结了在PADS V9.3中实现Layout与Router同步操作的具体方法以及该版本的其他新功能。这些知识点对于电子设计工程师来说非常重要,它能够帮助他们在PCB设计中更加高效和准确地完成任务。
本篇文章将深入介绍如何入门Android的Layout动画,我们将结合源码分析和使用工具来理解其工作原理。 首先,让我们了解什么是Layout动画。在Android中,布局动画是指当一个布局中的View首次显示或者被添加到布局时,...
2. LayOut 的使用场景:LayOut 可以创建演示看板、小型手册和幻灯片,并且可以作为排版软件和分析图制作软件使用。 3. LayOut 的启动和设置:在启动 LayOut 时,可以选择要排版的纸张大小,单击打开就可以了。如果...
Layout 还提供了一些API方法,允许在运行时动态控制布局,例如: - `toggle('region')`: 打开或关闭指定区域。 - `resize('region', value)`: 修改指定区域的大小。 - `destroy()`: 移除Layout,恢复原始DOM结构。 ...
使用方法** 使用 jQuery UI Layout 首先需要引入 jQuery 和 jQuery UI Layout 的库文件,然后在页面加载完成后调用 `$.layout()` 方法,传入配置对象来初始化布局。例如: ```javascript $(document).ready...
在`说明.htm`文件中,可能会详细解释FloatLayout的工作原理和使用方法。通常,自定义布局需要重写`onMeasure()`和`onLayout()`方法来计算和布置子视图的位置。`onMeasure()`用于测量每个子视图的大小,`onLayout()`...
通过阅读此帮助文件,即使是初次接触Sprint-Layout 6.0的设计师也能够迅速掌握软件的使用方法,尽快投入电路设计工作。 为了满足不同用户的个性化需求,Sprint-Layout 6.0还提供了灵活的配置选项。其中,LAYOUT60....
cadence virtuoso layout pcell Cadence Virtuoso Layout PCell 是一种基于 Cadence Virtuoso 平台的Layout设计工具,用于创建参数化的自定义细胞(PCell)。PCell 可以根据用户的需求进行参数化设置,例如 MOS 管...
需调用`getChildMeasureSpec()`生成子视图的测量规格,并使用`measure()`测量子视图,然后使用`layout()`方法设置子视图的位置。 4. **onDraw()**:绘制自定义布局的图形。如果只是布局,通常不需要重写此方法,因为...
Layout 提供了一些方法来控制其行为,如 `resize()` 用于调整整个布局的大小,`expandRegion()` 和 `collapseRegion()` 分别用于展开和折叠指定区域。 5. **事件**: - `onResize`: 当布局大小改变时触发。 - `...