0

Rails アプリで特定のフォームのオートコンプリートを開発しています。この目的のために、カスタムコントローラーメソッドで typeahead.js を使用しています。これまでのところ、機能していますが、フォーム内でこれらの値を再度使用する必要があります。これにより、送信ボタンを押すことができ、フォームが投稿され、レールによって正常に処理されます。これどうやってするの?これが今のコードです

.page-header
  %h1
    = @org.name
    %small= t('.title')
= form_for @org_admin, |
       url: organization_organization_admins_path(@organization) do |f|
  .form-group
    = f.label t('.user')
    = f.hidden_field :user, id: 'user_id'
    %input.typeahead{ :type => "text", :autocomplete => "off"}
= f.submit t('.submit'), class: 'btn btn-primary'
= link_to t('.back'), organization_organization_admins_path(@organization)
:javascript
  $(document).ready(function() {
  $('input.typeahead').typeahead({
    name: 'names',
    remote: "#{search_organization_organization_admins_path(@organization)}?term=%QUERY",
    engine: Hogan,
    template: '<p><strong>{{username}}</strong></p>',
    limit: 10
    }).on('typeahead:selected', function(e, data){
        $('#user_id').value = data.id
    });
  });

したがって、フォームの :user 属性に、コントローラーから返された json オブジェクトを入力したいと思います

4

1 に答える 1

0

気にしないでください、私は理解しました...この行への呼び出しを除いて、上記のコードは正しいパスにあります

$('#user_id').value = data.id

jQueryを使用して非表示の要素を選択しているため、代わりにjQuery val関数を使用する必要がありました

$('#user_id').val(data.id)
于 2013-11-08T18:03:28.573 に答える