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 来更新视图页面内容
对链接进行 ajax 调用单击以更新链接本身(Ruby on Rails)