最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Google Maps API V3 - Anyway to retrieve Autocomplete results instead of dropdown rendering it? - Stack Overflow

programmeradmin2浏览0评论

I need to render the results of google.maps.places.Autoplete in a custom way, instead of the default drop down menu.

Is there any way I can use the Google Maps API V3 to retrieve the same info of Autoplete, but in an Array per request instead of the API do the rendering for me?

PS1:

I wondered I could use the google.maps.places.PlaceSearchRequest. But, differently from Autoplete, it restricts my location. It cannot be used to search worldwide.

  • .html
  • .html

PS2:

The default way I am (currently) using Autoplete restricts me. I must pass an input element, and the API renders the dropdown, which I do NOT want.

var autoplete, input_el, place_changed_trigger_func;
input_el = <an input element>;
place_changed_trigger_func = function() {
  var place = autoplete.getPlace();
  // do whatever you want with place
};
autoplete = new google.maps.places.Autoplete(input_el, {types: ["geocode"]});
google.maps.event.addListener(autoplete, 'place_changed', place_changed_trigger_func);

I need to render the results of google.maps.places.Autoplete in a custom way, instead of the default drop down menu.

Is there any way I can use the Google Maps API V3 to retrieve the same info of Autoplete, but in an Array per request instead of the API do the rendering for me?

PS1:

I wondered I could use the google.maps.places.PlaceSearchRequest. But, differently from Autoplete, it restricts my location. It cannot be used to search worldwide.

  • http://code.google./apis/maps/documentation/javascript/reference.html
  • http://code.google./apis/maps/documentation/places/index.html

PS2:

The default way I am (currently) using Autoplete restricts me. I must pass an input element, and the API renders the dropdown, which I do NOT want.

var autoplete, input_el, place_changed_trigger_func;
input_el = <an input element>;
place_changed_trigger_func = function() {
  var place = autoplete.getPlace();
  // do whatever you want with place
};
autoplete = new google.maps.places.Autoplete(input_el, {types: ["geocode"]});
google.maps.event.addListener(autoplete, 'place_changed', place_changed_trigger_func);
Share Improve this question edited Apr 12, 2018 at 6:04 ekad 14.6k26 gold badges46 silver badges48 bronze badges asked Feb 14, 2012 at 12:07 Rafael XavierRafael Xavier 2,89928 silver badges35 bronze badges
Add a ment  | 

3 Answers 3

Reset to default 4

I believe this is the link that @jegnag meant to include.

https://developers.google./maps/documentation/javascript/places-autoplete#place_autoplete_service

You can access the array of results (places in addition to suggested search terms), you can even add your own custom results to this array, and display everything however you choose.

Have you explored the Autoplete function of the Places API webservice? That appears to be what you're looking for.

Try the AutopleteService class:

"You can use the AutopleteService class to retrieve the query or place prediction data returned from the Autoplete service. Calling either the getPlacePredictions() or getQueryPredictions() methods will return an array of five prediction objects of the form:"

发布评论

评论列表(0)

  1. 暂无评论