优先使用 字符串插值 来代替 字符串串联。
1
2
3
4
5
6
7
8
|
# bad email_with_name = user.name + ' <' + user.email + '>' # good email_with_name = "#{user.name} <#{user.email}>" # good email_with_name = format( '%s <%s>' , user.name, user.email) |
Consider padding string interpolation code with space. It more clearly sets the
code apart from the string.考虑使用空格填充字符串插值。它更明确了除字符串的插值来源。
1
|
"#{ user.last_name }, #{ user.first_name }" |
Consider padding string interpolation code with space. It more clearly sets the
code apart from the string.
考虑替字符串插值留白。這使插值在字符串里看起來更清楚。
1
|
"#{ user.last_name }, #{ user.first_name }" |
采用一致的字符串字面量引用风格。这里有在社区里面受欢迎的两种风格,它们都被认为非常好 -
默认使用单引号(选项 A)以及双引号风格(选项 B)。
(Option A) 当你不需要字符串插值或者例如 \t, \n, ' 这样的特殊符号的
时候优先使用单引号引用。
1
2
3
4
5
|
# bad name = "Bozhidar" # good name = 'Bozhidar' |
(Option B) Prefer double-quotes unless your string literal
contains " or escape characters you want to suppress.
除非你的字符串字面量包含 " 或者你需要抑制转义字符(escape characters)
优先使用双引号引用。
1
2
3
4
5
|
# bad name = 'Bozhidar' # good name = "Bozhidar" |
第二种风格可以说在 Ruby 社区更受欢迎些。该指南的字符串字面量,无论如何,
与第一种风格对齐。
不要使用 ?x 符号字面量语法。从 Ruby 1.9 开始基本上它是多余的,?x 将会被解释为 x (只包括一个字符的字符串)。
1
2
3
4
5
|
# bad char = ?c # good char = 'c' |
别忘了使用 {} 来围绕被插入字符串的实例与全局变量。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
class Person attr_reader :first_name , :last_name def initialize(first_name, last_name) @first_name = first_name @last_name = last_name end # bad - valid, but awkward def to_s "#@first_name #@last_name" end # good def to_s "#{@first_name} #{@last_name}" end end $global = 0 # bad puts "$global = #$global" # good puts "$global = #{$global}" |
在对象插值的时候不要使用 Object#to_s,它将会被自动调用。
1
2
3
4
5
|
# bad message = "This is the #{result.to_s}." # good message = "This is the #{result}." |
操作较大的字符串时, 避免使用 String#+ 做为替代使用 String#<<。就地级联字符串块总是比 String#+ 更快,它创建了多个字符串对象。
1
2
3
4
5
6
7
|
# good and also fast html = '' html << '<h1>Page title</h1>' paragraphs. each do |paragraph| html << "<p>#{paragraph}</p>" end |
When using heredocs for multi-line strings keep in mind the fact
that they preserve leading whitespace. It's a good practice to
employ some margin based on which to trim the excessive whitespace.
heredocs 中的多行文字会保留前缀空白。因此做好如何缩进的规划。这是一个很好的
做法,采用一定的边幅在此基础上削减过多的空白。
1
2
3
4
5
6
7
|
code = <<- END .gsub(/^\s+\|/, '' ) | def test | some_method | other_method | end END #=> "def test\n some_method\n other_method\nend\n" |