我正在尝试搜索里程半径内的所有供应商,但为了做到这一点,我需要我正在搜索的地址的坐标。事先抓住这些坐标是不可行的,因为地图搜索并没有经常使用。
所以,我想要做的是在点击链接时从Google Maps 获取坐标(如果我们还没有得到它们),然后继续默认的浏览器行为。这是我必须完成的代码:
HTML
<a href="/vendors/search" target="_blank" class="vendorMapSearch"
data-miles-radius="50" data-address="@Model.Address.SingleLine()"
data-customer-name="@Model.CustomerName" data-customer-id="@Model.CustomerId"
data-service-on="@Model.ServiceOn">Vendor Map Search</a>
的JavaScript
$(document).on('click', 'a.vendorMapSearch', function (e) {
console.log('HANDLE CLICK');
var $target = $(e.target),
data = $target.data();
if (!data.latitude || !data.longitude) {
console.log('HITTING GOOGLE MAPS');
var url = 'https://maps.googleapis.com/maps/api/geocode/json?language=en&sensor=false&address=' + data.address;
$.getJSON(url, function (resp) {
console.log('response received');
if (!resp.results.length) {
$('<div>Could not find coordinates for the address entered.</div>');
return;
}
$target.data('latitude', resp.results[0].geometry.location.lat);
$target.data('longitude', resp.results[0].geometry.location.lng);
$target.attr('href', $target.attr('href') + '?' + $.param($target.data()));
$target.trigger('coordinatesAcquired');
});
return false;
}
console.log('RETURNING TRUE');
return true;
});
$(document).on('coordinatesAcquired', function() {
console.log('COORDINATES ACQUIRED');
$('a.vendorMapSearch').trigger('click');
});
它给出了这个输出:
HANDLE CLICK
HITTING GOOGLE MAPS
XHR finished loading: (blah blah)
COORDINATES ACQUIRED
HANDLE CLICK
RETURNING TRUE
它看起来对我来说是正确的,但行为是它不会触发默认链接浏览器行为(至少在Chrome中),除非我再次单击该链接。任何人都知道这是怎么回事?
答案 0 :(得分:1)
触发器并没有真正点击a
,它只是启动了监听器。默认行为是触发,但在这里你可以做什么。如果触发了点击,您可以签入事件处理程序,然后手动更改页面:
if(e.isTrigger) window.location = this.href
或在另一个窗口中打开:
if(e.isTrigger) window.open(this.href, '_blank ')