分享编程~
 

HTML5+JS地图定位获取当前地址及经纬度

HTML5+JS百度地图展示实现定位获取当前详细地址及经纬度信息,不管是pc端还是移动端为了用户安全,定位时需要手动同意获取地理位置信息,有些浏览器会定位失败,仅供参考。

天天特卖抢好货

HTML5+JS百度地图展示实现定位获取当前详细地址及经纬度信息,不管是pc端还是移动端为了用户安全,定位时需要手动同意获取地理位置信息,有些浏览器会定位失败,电脑端直接用IE10、IE11、Edge可以浏览,安卓机用自带的浏览器,QQ浏览器或者微信以前可以现在不行了。仅供参考,直接示例源码:

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>HTML5+JS定位地图获取当前地址及经纬度-越加网</title>
	<meta name="keywords" content="HTML5+JS定位地图获取当前地址及经纬度">
	<meta name="description" content="HTML5+JS百度地图展示实现定位获取当前详细地址及经纬度信息,不管是pc端还是移动端为了用户安全,定位时需要手动同意获取地理位置信息,有些浏览器会定位失败,仅供参考,直接示例源码:">
	<script type="text/javascript" src="http://lib.sinaapp.com/js/jquery/1.7.2/jquery.min.js"></script>
	<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=wqBXfIN3HkpM1AHKWujjCdsi"></script>
	<script type="text/javascript" src="http://developer.baidu.com/map/jsdemo/demo/convertor.js"></script>
	<style type="text/css">
	*{ margin: 0px; padding: 0px;font-size:20px;}
	body{text-align: center;  height: 100%;overflow:hidden;}
	#allmap{ width: 100%;height: 100%; position: absolute;}
	</style>
</head>
<body>
    <div id="allmap"></div>
<script type="text/javascript">
$(function(){
	// 页面加载时执行getLocation函数
	window.onload = getLocation;  
    if(supportsGeoLocation()){
         //alert("你的浏览器支持 GeoLocation.");
    }else{
         alert("不支持 GeoLocation.")
    }
  // 检测浏览器是否支持HTML5
	function supportsGeoLocation(){
		return !!navigator.geolocation;
	}
  // 单次位置请求执行的函数             
    function getLocation(){
	    navigator.geolocation.getCurrentPosition(mapIt,locationError);
    }
  //定位成功时,执行的函数
	function mapIt(position){
		var lon = position.coords.longitude;
		   var lat = position.coords.latitude;
		   // alert("您位置的经度是:"+lon+" 纬度是:"+lat);
		var map = new BMap.Map("allmap");
		var point = new BMap.Point(""+lon+"",""+lat+"");
		map.centerAndZoom(point,19);
		var gc = new BMap.Geocoder();
			  translateCallback = function (point){
				  var marker = new BMap.Marker(point);
				  map.addOverlay(marker);
				  map.setCenter(point);
				  gc.getLocation(point, function(rs){
						var addComp = rs.addressComponents;
						if(addComp.province!==addComp.city){
						  var sContent =
						  "<div><h4 style='margin:0 5px 5px 0;padding:0.2em 0;'></h4>" + 
						  "<p style='margin:0;line-height:1.5;font-size:1.2rem;'>"+addComp.province + ", " + addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber+"</p>" + 
						  "</div>";}
						else{
						  var sContent =
						  "<div><h4 style='margin:0 5px 5px 0;padding:0.2em 0;font-size:1rem'></h4>" + 
						  "<p style='margin:0;line-height:1.5;font-size:1.2rem;'>"+ addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber+"</p>" + 
						  "</div>";
						}
						var infoWindow = new BMap.InfoWindow(sContent);
						map.openInfoWindow(infoWindow,point);
				  }); 
			  }                  
		BMap.Convertor.translate(point,0,translateCallback); 
	}
  // 定位失败时,执行的函数
	function locationError(error){
	  switch(error.code)
		{
		case error.PERMISSION_DENIED:
		  alert("无法定位.");
		  break;
		case error.POSITION_UNAVAILABLE:
		   alert("位置信息不可用.");
		  break;
		case error.TIMEOUT:
		   alert("请求超时.");
		  break;
		case error.UNKNOWN_ERROR:
		   alert("未知错误.");
		  break;
		}
	}
})
</script>
</body>
</html>

效果图例:

html5获取当前地址_图例


上一篇:PHP数据传递存储序列化serialize对象数组转字符串和反序列化下一篇:web客服QQ在线咨询临时会话
赞(18) 踩(0)
您说多少就多少,您的支持是我最大的动力
赏金
微 信
赏金
支付宝
本文连接: https://www.yj521.com/article/77.html
版权声明: 本文为原创文章,版权归《越加网》所有,分享转载请注明出处!