files/en-us/web/api/geolocation/getcurrentposition/index.md
{{securecontext_header}}{{APIRef("Geolocation API")}}
The getCurrentPosition() method of the {{domxref("Geolocation")}} interface is used to get the current position of the device.
Note that in addition to requiring a secure context this feature may be blocked by the geolocation Permissions-Policy, and also requires that explicit permission be granted by the user.
If required, the user will be prompted when this method is called.
The permission state can be queried using the geolocation user permission in the Permissions API.
getCurrentPosition(success)
getCurrentPosition(success, error)
getCurrentPosition(success, error, options)
success
error {{optional_inline}}
options {{optional_inline}}
maximumAge {{optional_inline}}
long value indicating the maximum age in milliseconds of a possible cached position that is acceptable to return. If set to 0, it means that the device cannot use a cached position and must attempt to retrieve the real current position. If set to {{jsxref("Infinity")}} the device must return a cached position regardless of its age. Default: 0.timeout {{optional_inline}}
long value representing the maximum length of time (in milliseconds) the device is allowed to take in order to return a position. The default value is {{jsxref("Infinity")}}, meaning that getCurrentPosition() won't return until the position is available.enableHighAccuracy {{optional_inline}}
true and if the device is able to provide a more accurate position, it will do so. Note that this can result in slower response times or increased power consumption (with a GPS chip on a mobile device for example). On the other hand, if false, the device can take the liberty to save resources by responding more quickly and/or using less power. Default: false.None ({{jsxref("undefined")}}).
const options = {
enableHighAccuracy: true,
timeout: 5000,
maximumAge: 0,
};
function success(pos) {
const crd = pos.coords;
console.log("Your current position is:");
console.log(`Latitude : ${crd.latitude}`);
console.log(`Longitude: ${crd.longitude}`);
console.log(`More or less ${crd.accuracy} meters.`);
}
function error(err) {
console.warn(`ERROR(${err.code}): ${err.message}`);
}
navigator.geolocation.getCurrentPosition(success, error, options);
{{Specifications}}
{{Compat}}