从Ruby数组中获取特定值并创建逗号分隔的字符串

时间:2012-06-25 16:03:56

标签: javascript ruby arrays erb

我需要一些Ruby数组jujitsu的帮助。

我有以下名为@tasks的数组:

[#<PivotalTracker::Story:0x007f9d6b8 @id=314, @url="http://www.pivotaltracker.com/", @created_at=#<DateTime: 2012-06-18T20:23:42+00:00 ((2456097j,73422s,0n),+0s,2299161j)>, @accepted_at=nil, @project_id=357031, @name="Test ", @description="This is the description for \"Test\"", @story_type="feature", @estimate=-1, @current_state="unstarted", @requested_by="joe jones", @owned_by=nil, @labels=nil, @jira_id=nil, @jira_url=nil, @other_id=nil, @integration_id=nil, @deadline=nil, @attachments=[]>, #<PivotalTracker::Story:0x007f9d6b8 @id=315, @url="http://www.pivotaltracker.com/", @created_at=#<DateTime: 2012-06-18T20:25:20+00:00 ((2456097j,73520s,0n),+0s,2299161j)>, @accepted_at=nil, @project_id=357031, @name="Test 2", @description="This is the description for \"Test 2\"", @story_type="feature", @estimate=-1, @current_state="unstarted", @requested_by="joe jones", @owned_by=nil, @labels=nil, @jira_id=nil, @jira_url=nil, @other_id=nil, @integration_id=nil, @deadline=nil, @attachments=[]>, #<PivotalTracker::Story:0x007f9d6b8 @id=316, @url="http://www.pivotaltracker.com/story/", @created_at=#<DateTime: 2012-06-18T20:25:26+00:00 ((2456097j,73526s,0n),+0s,2299161j)>, @accepted_at=nil, @project_id=357031, @name="Test 3", @description="Description for Test 3 ", @story_type="feature", @estimate=-1, @current_state="unstarted", @requested_by="joe jones", @owned_by=nil, @labels=nil, @jira_id=nil, @jira_url=nil, @other_id=nil, @integration_id=nil, @deadline=nil, @attachments=[]>] 

我的最终目标是在我的.erb视图中创建一个JavaScript数组,只包含上述数组中的ID值。

我正在考虑尝试类似的事情:

var myJSArray = [<%= @tasks.each { |t| print t.id.to_s+", " } %>];

然而,这显然在字符串的末尾附加了一个“,”,这是不可取的(即它返回“314,315,316”。。它似乎有点像黑客而不是正确的方式这样做。

有关如何正确执行此操作的任何想法?

谢谢!

更新:经过对SO的更多研究后,我似乎可以分两步完成这项工作:

@ids = @tasks.map { |t| t.id }

然后在视图中使用:

var myJSArray = [<%= @ids.map(&:to_s).join(", ") %>];

不确定这是否理想,或者是否可以在一个步骤中完成。

2 个答案:

答案 0 :(得分:2)

var myJSArray = [<%= j @tasks.map(&:id).join(',') %>];

或者你可能更喜欢这样的东西:

var myJSArray = <%= @tasks.map(&:id).to_json %>;

答案 1 :(得分:1)

使用Array#join

<%=print @task.map {|t| t.id.to_s}.join(', ') %>