当前位置: 首页 > 工具软件 > Ruby Fog > 使用案例 >

优美的Ruby

齐成和
2023-12-01

整理一些优化代码的方法和基本概念

strip_tags //格式化标签

Ruby map、each、select、inject、collect 、detect 、reject 方法特征

map:(collect是map的别名函数),对数组中每个元素进行表达式操作,原始数组不会被改变,返回执行表达式结果的新数组
[1,2,3,4,5,6,7,8,9,10].map{|e| e*3}  
=> [3, 6, 9, 12, 15, 18, 21, 24, 27, 30] 
[1,2,3,4,5,6,7,8,9,10].collect{|e| e == 3} 
=>[false, false, true, false, false, false, false, false, false, false]
each: 常用作数组的循环操作,对循环的参数做表达式操作,原数组不会被改变,返回原始数组
eg:[1,2,3,4,5,6,7,8,9,10].each{|e| print e.to_s + "###"} 
    => 1###2###3###4###5###6###7###8###9###10### 
    =>返回 [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] 
select: 相当于过滤器,返回符合表达式元素的新数组,如果所有都不符合表达式则返回空数组
eg:[1,2,3,4,5,6,7,8,9,10].select{|e| e == 3}
   =>  [3] 
eg:[1,2,3,4,5,6,7,8,9,10].select{|e| e*3}
  => [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
detect:(find的别名函数) 返回列表中第一个符合条件的元素
eg:[1,2,3,4,5,6,7,8,9,10].detect{|e| e == 3 || e == 2}
   =>  2 
inject: 在所声明的容器中注入符合条件的元素,累加器作用
eg:[1,2,3,4,5,6,7,8,9,10].inject{ |sum,e| sum += e } //其中sum为所声明的注入器 将累加后的结果最后注入到sum中并返回注入器最后结果
eg:[1,2,3,4,5,6,7,8,9,10].inject{|result,elem| result + elem} => 55 //此时inject没有带参数,这是result会为数组中第一个元素,elem为第二个元素,依次累加返回最后结果 
eg:  {1 => 'a',2 => 'b',3 =>'c'}.inject({}){|key,value| value} key => {} value => [3,'c'] 
reject: 去除列表中符合条件的元素
eg:[1,2,3,4,5,6,7,8,9,10].reject{|e| e==2 || e==8}
   => [1, 3, 4, 5, 6, 7, 9, 10] 

以下是对:require、load、include、extend的区别:

  1. require方法是加载一个文件,只加载一次,如果多次加载会返回false,一般在使用require加载一个文件的时候不需要加扩展名。如要加载test.rb文件时,require ‘test’。
  2. load方法跟require方法类似,也是加载一个文件,但是也有不同,就是它可以多次加载,而且必须制定扩展名。如要加载文件test.rb文件时, load “test.rb”
  3. include方法是引入模块,前提是你在映入了库之后,你可以在你的库文件中定义module,然后通过include引入,但是这里必须注意,使用include引入的module中的方法和变量为实例方法和实例变量,而不是类方法和类变量。更进一步说,即使你的类还在运行,这个时候你去改变了你引入的module的定义,你就会相应的改变引入该模块的类的行为。
    下例假设模块Log和类TestClass在相同的.rb文件。如果它们存在于多个文件, 则需要使用 load 或 require 导入文件。
module Log 
  def class_type
    "This class is of type: #{self.class}"
  end
end

class TestClass 
  include Log 
end

tc = TestClass.new.class_type
puts tc #This class is of type: TestClass
  1. Extend
    当你使用Extend来替换 Include 的时候, 你会添加模块里的方法为类方法, 而不是实例方法。详细请看例子:
module Log
  def class_type
    "This class is of type: #{self.class}"
  end
end

 class TestClass
  extend Log
  # ...
end

tc = TestClass.class_type
puts tc  # This class is of type: TestClass

当你在类中使用 Extend 来代替 Include, 如果你实例化 TestClass 并调用 class_type方法时,你将会得到 NoMethodError。再一次强调, 使用 Extend 时方法是类方法。

 类似资料: