Heim Web-Frontend H5-Tutorial HTML5 implementiert die Funktion zum Abrufen geografischer Standortinformationen und zur Positionierung_html5-Tutorialfähigkeiten

HTML5 implementiert die Funktion zum Abrufen geografischer Standortinformationen und zur Positionierung_html5-Tutorialfähigkeiten

May 16, 2016 pm 03:46 PM
html5 定位 获取地理位置信息

HTML5 bietet eine Geolokalisierungsfunktion (Geolocation-API), die den Standort des Benutzers bestimmen kann. Wir können diese Funktion von HTML5 verwenden, um Anwendungen basierend auf Geolokalisierungsinformationen zu entwickeln. In diesem Artikel erfahren Sie anhand von Beispielen, wie Sie HTML5 verwenden und die Baidu- und Google Maps-Schnittstellen verwenden, um genaue geografische Standortinformationen der Benutzer zu erhalten.

Quellcode-Download: Klicken Sie hier zum Herunterladen

So verwenden Sie die HTML5-Geolocation-Funktion

Geolocation ist eine neue Funktion von HTML5 und kann daher nur auf modernen Browsern ausgeführt werden, die HTML5 unterstützen, insbesondere auf Handheld-Geräten wie iPhones, bei denen die Geolokalisierung genauer ist. Zuerst müssen wir feststellen, ob der Gerätebrowser des Benutzers die Geolokalisierung unterstützt, und wenn ja, die geografischen Informationen abrufen. Beachten Sie, dass diese Funktion die Privatsphäre des Benutzers verletzen kann, wenn der Benutzer nicht zustimmt. Daher werden wir beim Zugriff auf die Anwendung gefragt, ob wir die Geolokalisierung zulassen möchten .

Code kopieren
Der Code lautet wie folgt:

Funktion getLocation(){
if (navigator.geolocation){
navigator.geolocation.getCurrentPosition(showPosition,showError);
}else{
warning("Der Browser unterstützt keine Geolokalisierung."); 🎜>}


Der obige Code kann erkennen, dass die Methode getCurrentPosition() ausgeführt wird, wenn das Benutzergerät die Geolokalisierung unterstützt. Wenn getCurrentPosition() erfolgreich ausgeführt wird, wird ein Koordinatenobjekt an die im Parameter showPosition angegebene Funktion zurückgegeben. Der zweite Parameter showError der getCurrentPosition()-Methode wird zur Behandlung von Fehlern verwendet. Er gibt die Funktion an, die ausgeführt werden soll, wenn das Abrufen der Position des Benutzers fehlschlägt .
Sehen wir uns zunächst die Funktion showError() an, die einige Methoden zur Fehlercodebehandlung festlegt, wenn die Ermittlung des geografischen Standorts des Benutzers fehlschlägt:



Code kopieren Der Code lautet wie folgt:
function showError(error){
switch(error.code) {
case error.PERMISSION_DENIED:
Alert („Positionierung fehlgeschlagen, der Benutzer weigerte sich, die Geolokalisierung anzufordern“); > case error. TIMEOUT:
warning("Positionierung fehlgeschlagen, Anforderung zum Abrufen des Benutzerstandorts ist abgelaufen");
break ");
break;
}
}


Schauen wir uns noch einmal die Funktion showPosition() an. Rufen Sie den Breiten- und Längengrad von coords auf, um den Breiten- und Längengrad des Benutzers zu erhalten.





Code kopieren

Der Code lautet wie folgt:

Funktion showPosition(position){
var lat = position.coords.latitude; //Latitude var lag = position.coords.longitude; //Longitude warning('Latitude:' lat ',Longitude:' lag); >}
Verwenden Sie Baidu Maps und Google Maps-Schnittstellen, um die Adresse des Benutzers zu erhalten


Oben haben wir erfahren, dass die Geolocation von HTML5 den Breitengrad und den Breitengrad des Benutzers ermitteln kann Längengrad, was wir also tun müssen Was benötigt wird, ist die Umwandlung abstrakter Längen- und Breitengrade in lesbare und aussagekräftige Informationen zum tatsächlichen geografischen Standort des Benutzers. Glücklicherweise bieten Baidu Maps und Google Maps diesbezüglich Schnittstellen. Wir müssen nur die von HTML5 erhaltenen Längen- und Breitengradinformationen an die Kartenschnittstelle übergeben, und der geografische Standort des Benutzers wird zurückgegeben, einschließlich Provinz- und Stadtinformationen und sogar Straßen. Hausnummer und andere detaillierte geografische Standortinformationen.
Wir definieren zunächst das Div, um den geografischen Standort auf der Seite anzuzeigen, und definieren jeweils id#baidu_geo und id#google_geo. Wir müssen nur die Schlüsselfunktion showPosition() ändern. Schauen wir uns zunächst die Interaktion der Baidu-Kartenschnittstelle an. Wir senden die Breiten- und Längengradinformationen über Ajax an die Baidu-Kartenschnittstelle, und die Schnittstelle gibt die entsprechenden Provinz-, Stadt- und Straßeninformationen zurück. Die Baidu-Kartenschnittstelle gibt eine Zeichenfolge von JSON-Daten zurück. Wir können die erforderlichen Informationen entsprechend unseren Anforderungen an div#baidu_geo anzeigen. Beachten Sie, dass hier die jQuery-Bibliothek verwendet wird und die jQuery-Bibliotheksdatei zuerst geladen werden muss.



Code kopieren

Der Code lautet wie folgt:

function showPosition(position){
var latlon = position.coords.latitude ',' position.coords.longitude;

//baidu
var url = "http://api.map.baidu.com/geocoder/v2/?ak=C93b5178d7a8ebdb830b9b557abce78b&callback=renderReverse&location=" latlon "&output=json&pois=0";
$.ajax({
Typ: "GET",
Datentyp: "jsonp",
URL: URL,
beforeSend: function(){
$("#baidu_geo ").html('正在定位...');
},
success: function (json) {
if(json.status==0){
$("#baidu_geo ").html(json.result.formatted_address);
}
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
$("#baidu_geo").html(latlon "地址位置获取失败");
}
});
});

再来看谷歌地图接口交互.同样我们将经纬度信息通过Ajax方式发送给谷歌地图接口,接口会返回相应的省市区街道详细信息.谷歌地图接口返回的也是一串JSON – JSON – JSON geo。

复制代码
代码如下:

function showPosition(position){
var latlon = position.coords.latitude ',' position.coords.longitude;

//google
var url = 'http://maps.google.cn/maps/api/geocode/json?latlng=' latlon '&sprache=CN';
$.ajax({
type: "GET",
url: url,
beforeSend: function(){
$("#google_geo").html('正在定位. ..');
},
success: function (json) {
if(json.status=='OK'){
var results = json.results;
$. every(results,function(index,array){
if(index==0){
$("#google_geo").html(array['formatted_address']);
}
});
}
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
$("#google_geo").html(latlon "地址位置获取失败"); > }
});
}

以上的代码分别将百度地图接口和谷歌地图接口整合到函数showPosition()中,我们可以根据实际情况进行调用.当然这只是一个简单的应用,我们可以根据这个简单的示例开发出很多复杂的应用,建议用手机浏览器访问DEMO演示.
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Tabellenrahmen in HTML Tabellenrahmen in HTML Sep 04, 2024 pm 04:49 PM

Anleitung zum Tabellenrahmen in HTML. Hier besprechen wir verschiedene Möglichkeiten zum Definieren von Tabellenrändern anhand von Beispielen für den Tabellenrand in HTML.

Verschachtelte Tabelle in HTML Verschachtelte Tabelle in HTML Sep 04, 2024 pm 04:49 PM

Dies ist eine Anleitung für verschachtelte Tabellen in HTML. Hier diskutieren wir anhand der entsprechenden Beispiele, wie man eine Tabelle innerhalb der Tabelle erstellt.

HTML-Rand links HTML-Rand links Sep 04, 2024 pm 04:48 PM

Anleitung zum HTML-Rand links. Hier besprechen wir einen kurzen Überblick über HTML margin-left und seine Beispiele sowie seine Code-Implementierung.

HTML-Tabellenlayout HTML-Tabellenlayout Sep 04, 2024 pm 04:54 PM

Leitfaden zum HTML-Tabellenlayout. Hier besprechen wir die Werte des HTML-Tabellenlayouts zusammen mit den Beispielen und Ausgaben im Detail.

HTML-Eingabeplatzhalter HTML-Eingabeplatzhalter Sep 04, 2024 pm 04:54 PM

Leitfaden für HTML-Eingabeplatzhalter. Hier besprechen wir die Beispiele für HTML-Eingabeplatzhalter zusammen mit den Codes und Ausgaben.

HTML-geordnete Liste HTML-geordnete Liste Sep 04, 2024 pm 04:43 PM

Leitfaden zur HTML-geordneten Liste. Hier besprechen wir auch die Einführung von HTML-geordneten Listen und Typen sowie deren Beispiele

Text in HTML verschieben Text in HTML verschieben Sep 04, 2024 pm 04:45 PM

Anleitung zum Verschieben von Text in HTML. Hier besprechen wir eine Einführung, wie Marquee-Tags funktionieren, mit Syntax und Beispielen für die Implementierung.

HTML-Onclick-Button HTML-Onclick-Button Sep 04, 2024 pm 04:49 PM

Anleitung zum HTML-OnClick-Button. Hier diskutieren wir deren Einführung, Funktionsweise, Beispiele und Onclick-Events in verschiedenen Veranstaltungen.

See all articles