This is an example showing how web application developers can incorporate the power of the BC Address Geocoder service into their application easily, including autoComplete functionality.
Result:
Documentation
This address auto-completion example makes use of jQuery UI's "autocomplete" function. The following stylesheet and scripts must be included in order to use jQuery UI:
<link rel="stylesheet" href="https://ajax.googleapis.com/ajax/libs/jqueryui/1.10.1/themes/smoothness/jquery-ui.css"/> <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.10.1/jquery.min.js"></script> <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.10.1/jquery-ui.min.js"></script>
Next you must include a text input field on your page, which you will use for geocoding with auto-completion:
<input type="text" id="geocodeField" placeholder="Type an address" />
Then you tell jQuery to perform auto-completion on this field, and provide it a function which will return a list of potential auto-completions for a given input, as well as a function to call when one of the suggestions is selected. Below, "geocodeSuggest" uses a jQuery ajax call to obtain the potential address matches from the geocoder REST API. An in-line function takes the selected suggestion and displays the selection's details in formatted JSON text in the result box.
// Geocode Address autocomplete $('#geocodeField').autocomplete({ minLength: 3, source: geocodeSuggest, select: function(evt, ui) { $('#output').text(JSON.stringify(ui.item.data, null, 4)); } }); // function for suggesting geocode autocompletion options function geocodeSuggest(request, response, options) { var params = { minScore: 50, maxResults: 5, echo: 'false', brief: true, autoComplete: true, addressString: request.term }; $.extend(params, options); $.ajax({ url: gcApi + "addresses.json", data: params, success: function(data) { var list = []; if(data.features && data.features.length > 0) { list = data.features.map( function(item) { return { value: item.properties.fullAddress, data: item } }); } response(list); }, error: function() { response([]); } }); }
For further information on jQuery UI's Autocomplete function, see the jQuery Documentation.
Here is a description of the options which can be used to configure the results returned by the REST API and address autoComplete suggestions:
- autoComplete
- brief
- echo
- maxResults
- minScore
- outputSRS
- setBack
- interpolation
- locationDescriptor
- bbox
- centre
- maxDistance
- localities
- localitiesNot
- matchPrecision
- matchPrecisionNot
For more information on these geocoder parameters, see the REST API Console.