我试图通过使用邻近搜索或textSearch迭代谷歌返回的结果来捕获特定城市的所有餐厅。到目前为止,我只能得到前 20 个结果。我希望在响应中看到一个名为"next_page_token"的参数,我可以在下一个请求中发送该参数以获取下一组结果,但是,无论我点击哪个 API 或半径的大小,我都不会在谷歌的响应中返回"next_page_token"。
我尝试在我的回调函数中专门请求"pagetoken"作为回调参数,令我惊讶的是,它确实为我提供了页面令牌的详细信息。我尝试在我的连续请求中将 pagetoken.l 映射到 pagetoken,但它仍然返回相同的结果集。
我已经在网上搜索了几个小时,无法解决这个问题。
使用 Node 和 VueJS 发出客户端请求。下面的示例代码位于脚本部分的一个 VueJS 模板中。文本搜索几乎相同,除了我用使用关键字执行搜索的查询替换位置和半径。
使用附近搜索的示例
initialize(addressData, placeResults) {
console.log("Address Data", addressData)
console.log("Place Results", placeResults)
this.location = {
lat: addressData.latitude,
lng: addressData.longitude
}
this.initMap()
},
initMap() {
console.log("Refs", this.$refs)
console.log("location", this.location)
let map = new google.maps.Map(this.$refs.map, {
center: this.location,
zoom: 12,
disableDefaultUI: true,
scrollwheel: false
})
let request = {
location: this.location,
radius: 10000,
type: ['restaurant']
}
let service = new google.maps.places.PlacesService(map)
service.nearbySearch(request, (results, status, pagetoken) => {
console.log("Results", results)
console.log("Status", status)
console.log("Pagetoken", pagetoken)
if (pagetoken.hasNextPage) {
this.hasNextPage = true
this.pagetoken = pagetoken.l
}
})
}
我不会发布结果,因为 JSON 很长,但结果只包含找到的餐厅数组,没有其他内容。
来自回调的页面令牌响应
{
"l": "CqQCHwEAAHGTZMjzfdC-1RcLP8jYBOGy7oUFztGWLSWOCQGAcHe4NgVLfJRl1Yl1GH0G-mju4-A-1fwtDChtmoSQn_qNBIkiK8co2KWy28M3BhV95yvLAswbfTIRwB9wZAev2aaRc3Yd2_nY9dWbFMhv-KppnTGKJj7dYndtj-yyUwV2evznSAE_t5Fcd7OYHmBXPHjSL54jfadw2B96wEx_Ju-5O30J14LlXLkJQZHhCNaD-kb-OAofXVeY5My1-LavHDgdkw49vTeiMou7jU4wB7m47ZSWAB2NChYt5tHLeHPA8n7aCRc40cEzNwpI8T3nwrw8tsuBx9Lbh8mToaUbULBSTzKQzr3DC6v2N4AGDuK4v6A_AdzKZVfhD_GNcM1olyQ2xRIQ0sAvkEOTSJ4ByvjcRXs_uhoUm0CPRm7lHLG593au02QlXTEjeg4",
"j": 1528657652795,
"hasNextPage": true
}
根据文档,附近搜索的回调函数中的第三个参数是类型为PlaceSearchPagination
的对象:
https://developers.google.com/maps/documentation/javascript/reference/3/places-service#PlaceSearchPagination
该PlaceSearchPagination
公开布尔类型的公共属性hasNextPage
和公共方法nextPage()
以获取下一页结果。
nextPage((- 获取下一页结果。使用提供给第一个搜索请求的相同回调函数。
我相信您应该使用以下代码来获取下一页结果(如果可用(
let service = new google.maps.places.PlacesService(map)
service.nearbySearch(request, (results, status, pagetoken) => {
console.log("Results", results)
console.log("Status", status)
console.log("Pagetoken", pagetoken)
if (pagetoken.hasNextPage) {
pagetoken.nextPage();
}
});