所以我正在关注这个过时的关于使用带有 rails 3 beta 的 jquery-ui 滑块的教程,因为它是我发现的唯一一个。
我的观点有剧本
<p>
<p>Showing all stocks between <span id="x_low_selected"><%= @price_range.first %></span> and <span id="x_high_selected"><%= @price_range.last %></span></p>
</p>
<div id="x_slider"></div>
<ul id="x_stock_list">
<%= render 'map' %>
</ul>
<script type="text/javascript">
$(function() {
$("#x_slider").slider( {
range: true,
step: 1,
max: <%= @price_range.last %>,
min: <%= @price_range.first %>,
values: [<%= @price_range.first %>, <%= @price_range.last %> ],
stop: function(event, ui) {
var prices = $('#x_slider').slider('option', 'values');
$('#x_low_selected').html(prices[0]);
$('#x_high_selected').html(prices[1]);
$.ajax({
url: 'http://localhost:3000/users',
type: "GET",
data: { low: prices[0], high: prices[1] },
dataType: 'json'
});
}
});
});
</script>
价格模型法
def self.low_high_prices
[User.minimum(:start), User.maximum(:end)]
end
以及 ajax 应该调用的控制器中的 index 方法
def index
@users = User.all
unless params[:low] && params[:high]
@users = User.all
@json = User.all.to_gmaps4rails do |user, marker|
marker.infowindow "<a href=/users/#{user.id}> #{user.name} </a>"
marker.title user.name
end
else
@json = User.where("start >= params[:low] AND end <= params[:high]).to_gmaps4rails do |user, marker|
marker.infowindow "<a href=/users/#{user.id}> #{user.name} </a>"
marker.title user.name
end
end
@price_range = User.low_high_prices
respond_to do |format|
format.html # index.html.erb
format.json { render json: @users }
end
end
有谁知道为什么当滑块停止滑动时没有将 ajax 调用发送到控制器?不确定我是否可以使用 :remote => true 因为滑块是在 div 内生成的。
谢谢
另外我目前正在使用带有 ruby 1.9.7 的 rails 3.2