延迟以防止对地图拖动进行多个ajax调用
Delay to prevent multiple ajax calls on map dragging
每次缩放或拖动地图时,我都会调用ajax,如下所示:
function initialize(lat, lng) {
var myLatlng = new google.maps.LatLng(lat,lng);
var mapOptions = {
mapTypeControl: false,
center: myLatlng,
zoom: 15,
};
map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions);
google.maps.event.addListener(map, 'zoom_changed', function() {
getResults(map.getBounds());
});
google.maps.event.addListener(map, 'dragend', function() {
getResults(map.getBounds());
});
};
function getListings(bounds){
data = {'South_Lat':bounds.getSouthWest().lat(), 'South_Lng':bounds.getSouthWest().lng(), 'North_Lat':bounds.getNorthEast().lat(), 'North_Lng':bounds.getNorthEast().lng()};
$.ajax({
type: "POST",
dataType: 'json',
url: "<?=$results_url;?>",
data: data,
success: function (json) {
// do something
}
});
}
然而,有时用户可能会在处理一个调用时继续拖动或缩放。一个例子是,当用户使用鼠标滚轮时,它会在每个缩放步骤上触发zoom_change。
为了防止服务器过载,我想添加1或2秒的延迟,以便在执行ajax之前等待进一步的缩放或拖动。
我如何在这里实现这一点?
使用下划线debounce(或其他库中的等效项)和空闲事件。
var debouncedLoad = _.debounce(getDataFromServer, 2000/*2 seconds*/);
google.maps.event.addListener(map, 'idle', function() {
debouncedLoad();
});
对于jquery,似乎有一个用于的插件
这是一个报告的错误http://code.google.com/p/gmaps-api-issues/issues/detail?id=1371.
建议使用事件"空闲"。
google.maps.event.addListener(map, 'idle', function() {
});
相关文章:
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- Javascript/jQuery中的并行Ajax调用
- 任何方式使AJAX调用Gmail API,而无需通过JS库
- node.js请求数据事件未在CORS ajax调用中触发
- 如何从ajax调用返回.wrap()元素
- Ajax调用在Firefox中不会自动响应
- AJAX调用中的非法调用
- 使用AJAX调用将GeoJSON数据拉入传单
- 在MVC 4中,对Controller的Ajax调用为空
- Jquery:对返回JSON数据的php脚本的Ajax调用
- 在ajax调用中阻止来自JS对象的函数
- 如何在MVC5中ajax调用的部分视图中引用外部javascript
- 页面加载后的Ajax调用
- 如何使用Ajax调用特定的控制器和操作来重定向用户
- curl和fileget_contents在ajax调用后不起作用
- 在任何AJAX调用之前触发一个javascript函数
- 无法在mvc视图中使用ajax调用获取操作返回的模型对象列表
- Ajax调用ERror Cross Origin REquest:在rails中自动完成大学列表
- ASP.NET MVC 3-在ajax调用后,重定向到新页面或生成页面刷新
- 点击功能没有'ajax调用动态元素(Backbone)后无法工作