Rails: Casting Objects as Arrays
I've run across Rails code like the following several times:
def emails
# force emails into an array if not already in one
if params[:email].nil?
[]
elsif params[:emails].is_a String
[params[:emails]]
else
params[:emails]
end
end
def do_something
emails.each do |email|
# do something
end
end
The above code gets the job done but it's not very clean.
It can be easily improved with the following:
def emails
Array.wrap(params[:emails])
end
def do_something
emails.each do |email|
# do something
end
end
Casting anything to an array will return an array. We now no longer care if a string
or an array comes through from the params we are covered in both cases. It's a cleaner
solution that saves us a few lines as well. This pattern is an example of "Don't
duplicate the functionality of a built-in library" from our guides. It's also worth checking out the docs for why #wrap
is being used here vs Kernel#Array
.
Written by richrines
Related protips
8 Responses
data:image/s3,"s3://crabby-images/54a0d/54a0d97799667f9015765e9995ae9feb59117d6b" alt=""
Nice tip - thanks!
over 1 year ago
·
data:image/s3,"s3://crabby-images/6b0c2/6b0c2908e0cf988f65e567183764e3aa9a598d54" alt=""
Very convenient. Thanks!
over 1 year ago
·
data:image/s3,"s3://crabby-images/de041/de041b6c1a608117eb20b981d2752fd746e9be0e" alt=""
Why not [*param[:emails]]
?
over 1 year ago
·
data:image/s3,"s3://crabby-images/792f6/792f6baa3aa2d338bdcb76674fbcc917f0f170c2" alt=""
I find this really helpful. Thanks.
over 1 year ago
·
data:image/s3,"s3://crabby-images/3b2ae/3b2aed368f07a4908cea46c56f345bade73b2138" alt=""
Pro Tip
over 1 year ago
·
data:image/s3,"s3://crabby-images/96bea/96bea2b550a71e340ae6a73af6760ddea932eb8c" alt=""
Very succint!
over 1 year ago
·
data:image/s3,"s3://crabby-images/cad27/cad276af9bfe014193ac4581fb20ba5b2febec27" alt=""
Cool. Something to remember.
over 1 year ago
·
Have a fresh tip? Share with Coderwall community!
Post
Post a tip
Best
#Ruby
Authors
Sponsored by #native_company# — Learn More
#native_title#
#native_desc#