class Project < ActiveRecord::Base has_many :tasks def self.all_names find(:all).collect(&:name) end end
这里的
find(:all).collect(&:name)
显得比较奇怪,因为之前几乎没见过"&"加":"这么用的,在这里,self.all_names会返回一个包含了所有项目名字的集合比如 ["Rails Project","Homework"],上面的代码等价于下面这些代码
find(:all).collect{ |p| p.name }
得益于to_proc的特性,我们还可以做这种事情
find(:all).collect(&:name).collect(&:downcase)
它会返回这样的东西 ["rails project","homework"]
如果你熟悉MVC,那么这里的layouts可以理解为View里面的东西,灵活的rails可以让你通过多种方式来渲染layouts。
全局layouts:在views/layouts中添加application.html.erb,写上html基本的东西,然后加上一句<%= yield%>就能召唤其他的view了,比如此时的views/posts中的所有view便会自动加上application.html.erb里面的内容,但是,如果你这个时候在views/layouts里面除了添加application.html.erb还加上一个posts.html.erb(当然要用<%= yield%>来召唤其他的view),那么在views/posts中的view便会加载posts.html.erb而不是application.html.erb里面的内容了。
你也能在controller中添加需要渲染的layouts
class PostsController < ApplicationController layout "admin" def index @posts = Post.all end end
你也可以在选择layouts之前加一些判断,这样就能实现登陆与没有登陆的用户看见不同view的功能了:
class PostsController < ApplicationController layout :user_layout def index @posts = Post.all end protected def user_layout if current_user.login? "admin" else "application" end end end当然,你更可以在action里面添加
def index @posts = Post.all render :layout => "posts" end
你需要在index.html.erb中添加
<% content_for :head do%> <%= stylesheet_link_tag "project"%> <% end %>这样,rails就能到app/assets/stylesheets中去寻找一个叫project的css文件,但是,此时你还需要在application.html.erb中召唤一下,才能在刷新页面之后看见效果
<%= yield :head %>
Filter Sensitive Logs
为了安全可以在ApplicationController中添加
class ApplicationController < ActionController::Base filter_parameter_logging "password" end通过filter_parameter_logging你可以过滤所有你想过滤的字段