AJAX 日历更新页面 rails 4

Posted

技术标签:

【中文标题】AJAX 日历更新页面 rails 4【英文标题】:AJAX calendar update page rails 4 【发布时间】:2014-03-09 19:15:08 【问题描述】:

我正在使用 jQuery 的 datepicker 来显示日历。当用户单击某个日期时,页面应呈现该特定日期的有效信息(在本例中为可用座位表)。

我可以看到我的日期在更改时通过 AJAX 传递,但从未呈现模板。部分如何知道从控制器获取@schedule?我做错了什么?

查看

<p>
  Date:
  <%= text_field "Date", "", :class => 'datepicker'%>
</p>

js

$(document).ready(function() 
    if($('.datepicker').length)
      $('.datepicker').datepicker(
        dateFormat: 'yy-mm-dd'
      );

    

    $('.datepicker').change(function()

      $.ajax(
        data: Date: $('.datepicker').val(),
      )
    );
  );

控制器

def show
   return unless @product

   @variants =    
   @product.variants_including_master.active(current_currency).includes([:option_values, 
   :images])

   @product_properties = @product.product_properties.includes(:property)


   @schedule = FlightSchedule.where(:date => params[:Date]).available_slots

   respond_to do |format|
     format.html
     format.js
   end

   referer = request.env['HTTP_REFERER']
   if referer
     begin
       referer_path = URI.parse(request.env['HTTP_REFERER']).path
       # Fix for #2249
     rescue URI::InvalidURIError
       # Do nothing
     else
       if referer_path && referer_path.match(/\/t\/(.*)/)
         @taxon = Spree::Taxon.find_by_permalink($1)
       end
     end
   end
end

js.erb

$('#seat_table').html('<%= escape_javascript render("seat_table")%>');

部分

<table>
    <th> Available Times </th>
    <th colspan='5'> Available Seats </th>
    <% @schedule.each do |available| %>
      <tr>
        <td>
          <%= available.time.strftime("%l:00") %>
        </td>
        <% @product.variants_and_option_values.each_with_index do |variant, index| %>

          <td>
            <% if available.seat_available?(available, variant.option_value('seat')) %>
              <%= check_box_tag "variants[#variant.id]", "1" %>
              <label for="<%= ['variants', @product.id, variant.id].join('_') %>">
                <span class="variant-description">
                  <%= variant.option_value('seat') %>
                </span>
              </label>
            <% else %>
              <label for="<%= ['variants', @product.id, variant.id].join('_') %>">
                <span class="variant-description">
                  <%= variant.option_value('seat') %>
                </span>
              </label>
            <% end %>
          </td>

        <% end %>
      </tr>
    <% end %>
</table>

日志的开始;日期已过,正在调用正确的操作。

    Started GET "/products/flight-simulation?Date=2014-03-31" for 127.0.0.1 at 2014-03-09 14:57:57 -0400
Processing by Spree::ProductsController#show as */*
  Parameters: "Date"=>"2014-03-31", "id"=>"flight-simulation"

【问题讨论】:

【参考方案1】:

我可以立即看到的一件事是您缺少数据类型。

改变

$('.datepicker').change(function()

      $.ajax(
        data: Date: $('.datepicker').val(),
      )
    );

$('.datepicker').change(function()

      $.ajax(
        data: Date: $('.datepicker').val(),
        dataType : 'script'
      )
    );

【讨论】:

以上是关于AJAX 日历更新页面 rails 4的主要内容,如果未能解决你的问题,请参考以下文章

Rails 4 - 通过使用 AJAX UJS 的集合中的链接更新表

如何在简单的 Rails 应用程序中调用 ajax 来更新视图页面内容

Rails 通过 ajax 提交表单并更新视图

对链接进行 ajax 调用单击以更新链接本身(Ruby on Rails)

Rails 4 引发 ArgumentError(参数数量错误(2 对 1)):通过 AJAX POST 更新时

使用ajax每X秒更新一次html页面