1

我有一个从 Foursquare 返回的 JSON 数组;让我们称之为@venues。我希望能够通过下拉框“选择”一个场地,并且我希望它成为表单的一部分。

这意味着我希望能够按名称选择特定场所(即在本例中为Hotel Utah Saloon),并将其保存id到模型中。澄清一下,我只会保存我选择的场所,而不是全部。

通过研究,我发现自己在 、 和 之间select感到collection_select困惑select_tag。请记住,这是直接来自JSON.parse方法的 JSON,而不是数据库模型。

如何在表单中创建此下拉菜单?

为了澄清,@venues看起来像这样:

[
            {
               "beenHere":8,
               "venue":{
                  "id":"3fd66200f964a52023f11ee3",
                  "name":"Hotel Utah Saloon",
                  "contact":{
                     "phone":"4155466300",
                     "formattedPhone":"(415) 546-6300",
                     "twitter":"hotelutah"
                  },
                  "location":{
                     "address":"500 4th St",
                     "crossStreet":"Corner of Bryant",
                     "lat":37.77947007181946,
                     "lng":-122.39816943501836,
                     "postalCode":"94107",
                     "city":"San Francisco",
                     "state":"CA",
                     "country":"United States",
                     "cc":"US"
                  },
                  "categories":[
                     {
                        "id":"4bf58dd8d48988d1e9931735",
                        "name":"Rock Club",
                        "pluralName":"Rock Clubs",
                        "shortName":"Rock Club",
                        "icon":"https:\/\/foursquare.com\/img\/categories\/arts_entertainment\/musicvenue_rockclub.png",
                        "parents":[
                           "Arts & Entertainment",
                           "Music Venues"
                        ],
                        "primary":true
                     }
                  ],
                  "verified":true,
                  "stats":{
                     "checkinsCount":6654,
                     "usersCount":3330,
                     "tipCount":50
                  },
                  "likes":{
                     "count":0,
                     "groups":[

                     ]
                  },
                  "beenHere":{
                     "count":0
                  }
               }
            }
        ]
4

1 回答 1

1

控制器

@venues = JSON.parse @venues

看法

<%= select(:model, :venue_id, @venues.map {|v| [ v['venue']['name'], v['venue']['id'] ] }) %>

或者更清洁:

控制器

@venues = JSON.parse @venues
@venues_list = @venues.map { |v| v['venue'] }

看法

<%= select(:model, :venue_id, @venues_list.map {|v| [ v['name'], v['id'] ] }) %>

有关选择助手的更多信息。

于 2012-09-26T07:52:29.293 回答