1

出于某种原因,当我加载部分并单击文本框以调出日期选择器时,我必须单击文本框,然后在日期选择器出现之前单击文本框。任何人都可以看到任何错误或如何修复它,以便在第一次单击文本框时出现日期选择器?我正在使用 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 partial 文本框所在

<%= 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>
4

1 回答 1

3

打电话

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

不打开日期选择器,它只是将日期选择器绑定到该元素,这意味着它将对点击做出反应并打开日期选择器。

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

于 2012-11-15T08:23:27.540 回答