欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS使用百度地圖API自動獲取地址和經緯度操作示例

 更新時間:2019年04月16日 11:50:43   作者:Zhihua_W  
這篇文章主要介紹了JS使用百度地圖API自動獲取地址和經緯度操作,結合實例形式分析了javascript與百度地圖API接口交互實現獲取地址與經緯度相關操作技巧,需要的朋友可以參考下

本文實例講述了JS使用百度地圖API自動獲取地址和經緯度操作。分享給大家供大家參考,具體如下:

在實際工作中我們經常會遇到這樣的問題,但是當我們去看百度API的時候往往又達不到我們的要求。

故此,本篇博文講述如何使用百度地圖API自動獲取地址和經緯度:

1、HTML代碼如下

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>點擊地圖獲取地址和經緯度map,address,lng,lat</title>
  <meta name="robots" content="noindex, nofollow">
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  <!-- 將百度地圖API引入,設置好自己的key -->
  <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=7a6QKaIilZftIMmKGAFLG7QT1GLfIncg"></script>
</head>
<body>
<div class="main-div">
  <form method="post" action="" name="theForm" enctype="multipart/form-data" onsubmit="return validate()">
    <table cellspacing="1" cellpadding="3" width="100%">
      <tr>
        <td class="label">經度</td>
        <td><input type="text" name="lng" id="lng" value=""/>
        </td>
      </tr>
      <tr>
        <td class="label">緯度</td>
        <td><input type="text" name="lat" id="lat" value=""/>
        </td>
      </tr>
      <tr>
        <td class="label">地址</td>
        <td>
          <input type='text' value='' name='sever_add' id='sever_add' readonly>
          <input type='button' value='點擊顯示地圖獲取地址經緯度' id='open'>
        </td>
      </tr>
    </table>
  </form>
  <div id='allmap' style='width: 50%; height: 50%; position: absolute; display: none'></div>
</div>
</body>
</html>

2、JS代碼如下

<script type="text/javascript">
  function validate() {
    var sever_add = document.getElementsByName('sever_add')[0].value;
    if (isNull(sever_add)) {
      alert('請選擇地址');
      return false;
    }
    return true;
  }
  //判斷是否是空
  function isNull(a) {
    return (a == '' || typeof(a) == 'undefined' || a == null) ? true : false;
  }
  document.getElementById('open').onclick = function () {
    if (document.getElementById('allmap').style.display == 'none') {
      document.getElementById('allmap').style.display = 'block';
    } else {
      document.getElementById('allmap').style.display = 'none';
    }
  }
  var map = new BMap.Map("allmap");
  var geoc = new BMap.Geocoder();  //地址解析對象
  var markersArray = [];
  var geolocation = new BMap.Geolocation();
  var point = new BMap.Point(116.331398, 39.897445);
  map.centerAndZoom(point, 12); // 中心點
  geolocation.getCurrentPosition(function (r) {
    if (this.getStatus() == BMAP_STATUS_SUCCESS) {
      var mk = new BMap.Marker(r.point);
      map.addOverlay(mk);
      map.panTo(r.point);
      map.enableScrollWheelZoom(true);
    }
    else {
      alert('failed' + this.getStatus());
    }
  }, {enableHighAccuracy: true})
  map.addEventListener("click", showInfo);
  //清除標識
  function clearOverlays() {
    if (markersArray) {
      for (i in markersArray) {
        map.removeOverlay(markersArray[i])
      }
    }
  }
  //地圖上標注
  function addMarker(point) {
    var marker = new BMap.Marker(point);
    markersArray.push(marker);
    clearOverlays();
    map.addOverlay(marker);
  }
  //點擊地圖時間處理
  function showInfo(e) {
    document.getElementById('lng').value = e.point.lng;
    document.getElementById('lat').value = e.point.lat;
    geoc.getLocation(e.point, function (rs) {
      var addComp = rs.addressComponents;
      var address = addComp.province + addComp.city + addComp.district + addComp.street + addComp.streetNumber;
      if (confirm("確定要地址是" + address + "?")) {
        document.getElementById('allmap').style.display = 'none';
        document.getElementById('sever_add').value = address;
      }
    });
    addMarker(e.point);
  }
</script>

將js代碼放入到html中,我們可以得到效果圖如下:

更多關于JavaScript相關內容還可查看本站專題:《JavaScript數學運算用法總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript數組操作技巧總結》、《JavaScript事件相關操作與技巧大全》、《JavaScript操作DOM技巧總結》及《JavaScript字符與字符串操作技巧總結

希望本文所述對大家JavaScript程序設計有所幫助。

相關文章

  • 不同瀏覽器對回車提交表單的處理辦法

    不同瀏覽器對回車提交表單的處理辦法

    在瀏覽器中填寫表單的時,可以直接在“文本框”中敲擊“Enter”來提交表單,很是方便。
    2010-02-02
  • javascript使用eval或者new Function進行語法檢查

    javascript使用eval或者new Function進行語法檢查

    使用代碼來實現分析代碼的語法,這是一件極其痛苦的事情。簡單的解決辦法是:使用腳本引擎自己的語法檢查,比方說eval( ) 或者new Function( )。
    2010-10-10
  • js活用事件觸發(fā)對象動作

    js活用事件觸發(fā)對象動作

    現在基本上我很少在對象里面寫事情觸發(fā)行為了,因為感覺那樣做相同的對象代碼利用率太低,容易導致代碼冗余.
    2008-08-08
  • JavaScript中實現無縫滾動、分享到側邊欄實例代碼

    JavaScript中實現無縫滾動、分享到側邊欄實例代碼

    本文給通過js代碼實現無縫滾動,側邊欄效果,在項目中經常會遇到,下面小編把代碼整理分享到腳本之家平臺,供大家參考
    2016-04-04
  • 使用Dropzone.js上傳的示例代碼

    使用Dropzone.js上傳的示例代碼

    本篇文章主要介紹了使用Dropzone.js上傳的示例代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • Javascript 類型轉換、封閉函數及常見內置對象操作示例

    Javascript 類型轉換、封閉函數及常見內置對象操作示例

    這篇文章主要介紹了Javascript 類型轉換、封閉函數及常見內置對象操作,結合實例形式分析了JavaScript類型顯示轉換、隱式轉換、變量作用域、封閉函數及常用內置對象相關操作技巧,需要的朋友可以參考下
    2019-11-11
  • JSON生成Form表單的方法示例

    JSON生成Form表單的方法示例

    JSON表單是一個基于React的抽象組件,它可以把JSON數據格式描述的表單轉換成項目中的表單,這篇文章主要介紹了JSON生成Form表單的方法示例,感興趣的小伙伴們可以參考一下
    2018-11-11
  • uni-app和原生小程序混合開發(fā)的具體實現過程

    uni-app和原生小程序混合開發(fā)的具體實現過程

    最近項目中遇到了一些功能需要與原生進行混合開發(fā),所以下面這篇文章主要給大家介紹了關于uni-app和原生小程序混合開發(fā)的具體實現過程,需要的朋友可以參考下
    2022-07-07
  • js防止表單重復提交實現代碼

    js防止表單重復提交實現代碼

    重復提交、重復刷新、防止后退等等都是屬于系統(tǒng)為避免重復記錄而需要解決的問題,在客戶端去處理需要針對每一種的可能提出相應的解決方案,然而在服務器端看來只不過是對于數據真實性的檢驗問題
    2012-09-09
  • js控住DOM實現發(fā)布微博效果

    js控住DOM實現發(fā)布微博效果

    這篇文章主要為大家詳細介紹了js控住DOM實現發(fā)布微博效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08

最新評論