这两个月比较忙,没有时间更新BLOG,今天开始继续。
ruby 中的block 和iterator 为我们在迭代编程中提供了更简单和自然的方法,block 跟随在方法调用后面,以{}包含代码部分。方法内部用yield调用block中的代码内容,block 的作用简单的说就是影响方法体内的代码行为,类似的功能比如在C#里的delegate,c/c++里的方法指针。
有了block,在数组的循环应用中就可以写出十分简洁的语句
打印数组元素中的第一个字符,这里用到了数组的each方法。
计算int数组的和,这里用到了inject方法,sum是用来得到执行的值,等价于sum = sum+item,
最后返回sum。
下面再看看一个Block的实际应用
在Rails中layout是做为模板页使用的,可有的时候我们需要在不同的页面调用不同的JS,又不想全部写在模板页里面,这个时候可以使用block来灵活调用.
在ApplicationHelper module里定义pagejs方法
然后在layout/index.rhtml 里加入
最后在要使用的view页面的第一行调用
呈现出的html源码中就会出现
<script src="/javascripts/user.js?1207145282" type="text/javascript"></script>
ruby 中的block 和iterator 为我们在迭代编程中提供了更简单和自然的方法,block 跟随在方法调用后面,以{}包含代码部分。方法内部用yield调用block中的代码内容,block 的作用简单的说就是影响方法体内的代码行为,类似的功能比如在C#里的delegate,c/c++里的方法指针。
def three_times
i=1
while i<4
yield i
i +=1;
end
end
three_times{ |i| puts i}
#output
#1
#2
#3
有了block,在数组的循环应用中就可以写出十分简洁的语句
打印数组元素中的第一个字符,这里用到了数组的each方法。
%w{hello world ruby}.each { |str| puts str[0,1] }
#output
#h
#w
#r
计算int数组的和,这里用到了inject方法,sum是用来得到执行的值,等价于sum = sum+item,
最后返回sum。
puts [1,3,5,7,9].inject{ |sum,item| sum+item }
#output
#25
下面再看看一个Block的实际应用
在Rails中layout是做为模板页使用的,可有的时候我们需要在不同的页面调用不同的JS,又不想全部写在模板页里面,这个时候可以使用block来灵活调用.
在ApplicationHelper module里定义pagejs方法
def pagejs(*jsname)
jsname.each{|item| content_for("pagejs"){ javascript_include_tag(item) }}
end
然后在layout/index.rhtml 里加入
<%= yield :pagejs %>
最后在要使用的view页面的第一行调用
<%pagejs("user")%>
呈现出的html源码中就会出现
<script src="/javascripts/user.js?1207145282" type="text/javascript"></script>