Jquery-ui datepicker仅在文本框第二次聚焦后出现

时间:2012-11-15 08:08:18

标签: javascript ruby-on-rails-3 jquery-ui coffeescript jquery-ui-datepicker

出于某种原因,当我加载部分并且我单击文本框以显示日期选择器时,我必须单击文本框,然后在出现日期选择器之前单击文本框中的返回。任何人都可以看到任何错误或如何解决它,以便第一次单击文本框时出现datepicker?我正在使用ruby 1.9.3和rails 3.2.8

users.js.coffeescript

$("form[data-update-target]").live "ajax:success", (evt, data) ->
  target = $(this).data("update-target")
  $("#" + target).html data

$("#update-container").on 'click', '#event_start_at_date', (evt) ->
  $("#event_start_at_date").datepicker({ dateFormat: "yy-mm-dd" })

$("#update-container").on 'click', '#event_end_at_date', (evt) ->
  $("#event_end_at_date").datepicker({ dateFormat: "yy-mm-dd" })

_event部分文本框位于

<%= form_for(@event) do |f| %>
  <div class="field">
  <%= f.label 'start date' %>*
  <%= f.text_field :start_at_date, :class => 'start_at_date', :size => 10, :maxlength => 10 %> 
  <%= f.text_field :start_at_time, :size => 5, :maxlength => 5 %>
</div>
<div class="field">
  <%= f.label 'end_date' %>*
  <%= f.text_field :end_at_date, :class => 'end_at_date', :size => 10, :maxlength => 10 %> 
  <%= f.text_field :end_at_time, :size => 5, :maxlength => 5 %>
</div>
<% end %>

用户new.html.erb的新页面

<%= form_tag({:controller => 'users', :action => 'preview'}, :remote => true, :'data-update-target' => 'update-container') do %>
  <%= radio_button_tag(:page_type, 'event', false, :class => 'submit') %>
  <%= label_tag(:page_type, "Event") %>
  <br/>
<% end %>
<div id="update-container">
</div>

1 个答案:

答案 0 :(得分:3)

调用

$("#event_start_at_date").datepicker({ dateFormat: "yy-mm-dd" })

不会打开datepicker,只是将datepicker绑定到该元素,这意味着它会对点击做出反应并打开datepicker。

您应该在加载DOM时将日期选择器绑定到元素,而不是单击处理程序。