AngularJs 利用百度地图API 定位当前位置 获取地址信息

发布时间 - 2026-01-10 22:37:36    点击率:

第一、申请百度密钥  很简单的几步就搞定

第二、引入文件

<!-- 百度地图定位 -->
<script src="http://api.map.baidu.com/components?ak=WUfZTjKPuZ2G5RmgD0Psejv6XOmIEQVQ"></script> 
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=WUfZTjKPuZ2G5RmgD0Psejv6XOmIEQVQ"></script> 

第三、绑定数据到你要显示的输入框内

完整地址:<input type="text" ng-model="all"/><br>
所处城市:<input type="text" ng-model="shi"/><br>
所处区域:<input type="text" ng-model="qu"/><br>
所处街道:<input type="text" ng-model="jiedao"/> 

第四、控制器中代码

angular.module('myApp')
.controller('myCtrl',function($scope) {
 //获取地理位置信息 
   $scope.getAddr = function() { 
    var geolocation = new BMap.Geolocation(); 
    geolocation.getCurrentPosition( 
     //获取位置信息成功 
     function(position){ 
      if(this.getStatus() == BMAP_STATUS_SUCCESS){ 
       $scope.longitude = position.point.lng; 
       $scope.latitude = position.point.lat; 
       // 根据坐标得到地址描述  
       $scope.getGeo(); 
      }  
     },{ 
      // 指示浏览器获取高精度的位置,默认为false 
      enableHighAccuracy: true, 
      // 指定获取地理位置的超时时间,默认不限时,单位为毫秒 
      // timeout: 5000, 
      // 最长有效期(30S),在重复获取地理位置时,此参数指定多久再次获取位置 
      maximumAge: 30*1000 
     }); 
   }; 
  $scope.getGeo = function() {
  var myGeo = new BMap.Geocoder();
  // 根据坐标得到地址描述
  myGeo.getLocation(new BMap.Point($scope.longitude,$scope.latitude),
  function(result) {
   if (result) {
   $scope.geoaddress = {
   'fulladdress' : result.addressComponents.city+ result.addressComponents.district+ result.addressComponents.street,
   'city' : result.addressComponents.city,
   'area' : result.addressComponents.district,
   'street' : result.addressComponents.street,
   };
   $scope.all = result.addressComponents.city+ result.addressComponents.district+ result.addressComponents.street;
   $scope.shi = result.addressComponents.city;
   $scope.qu = result.addressComponents.district;
   $scope.jiedao = result.addressComponents.street;
   alert(JSON.stringify($scope.all))
   } else {
   $scope.showAlert("定位失败,地址解析失败");
   }
  });
  };
  } ]);

第五、完整代码如下:(大体思路就是这样!这里做个标记留给以后的自己)

<!DOCTYPE html>
<html>
<meta charset="utf-8">
<script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
<script src="http://api.map.baidu.com/components?ak=WUfZTjKPuZ2G5RmgD0Psejv6XOmIEQVQ"></script> 
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=WUfZTjKPuZ2G5RmgD0Psejv6XOmIEQVQ"></script> 
<body>
<div ng-app="myApp" ng-controller="myCtrl">
<button type="button" ng-click='getAddr()'>点击定位</button><br>
完整地址:<input type="text" ng-model="all"/><br>
所处城市:<input type="text" ng-model="shi"/><br>
所处区域:<input type="text" ng-model="qu"/><br>
所处街道:<input type="text" ng-model="jiedao"/>
</div>
<script>
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope) {
  //获取地理位置信息 
 $scope.getAddr = function() { 
 var geolocation = new BMap.Geolocation(); 
 geolocation.getCurrentPosition( 
 //获取位置信息成功 
 function(position){ 
 if(this.getStatus() == BMAP_STATUS_SUCCESS){ 
  $scope.longitude = position.point.lng; 
  $scope.latitude = position.point.lat; 
  // 根据坐标得到地址描述  
  $scope.getGeo(); 
  }  
  },{ 
  // 指示浏览器获取高精度的位置,默认为false 
  enableHighAccuracy: true, 
  // 指定获取地理位置的超时时间,默认不限时,单位为毫秒 
  // timeout: 5000, 
  // 最长有效期(30S),在重复获取地理位置时,此参数指定多久再次获取位置 
  maximumAge: 30*1000 
  }); 
  }; 
  $scope.getGeo = function() {
  var myGeo = new BMap.Geocoder();
  // 根据坐标得到地址描述
  myGeo.getLocation(new BMap.Point($scope.longitude,$scope.latitude),
  function(result) {
  if (result) {
   $scope.geoaddress = {
   'fulladdress' : result.addressComponents.city+ result.addressComponents.district+ result.addressComponents.street,
   'city' : result.addressComponents.city,
   'area' : result.addressComponents.district,
   'street' : result.addressComponents.street,
   };
   $scope.all = result.addressComponents.city+ result.addressComponents.district+ result.addressComponents.street;
   $scope.shi = result.addressComponents.city;
   $scope.qu = result.addressComponents.district;
   $scope.jiedao = result.addressComponents.street;
   alert(JSON.stringify($scope.all))
   } else {
   $scope.showAlert("定位失败,地址解析失败");
   }
  });
  };
});
</script>
</body>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# AngularJs  # 百度地图  # javascript+mapbar实现地图定位  # js实现百度地图定位于地址逆解析  # 显示自己当前的地理位置  # Android百度地图定位后获取周边位置的实现代码  # 基于Android实现百度地图定位过程详解  # ios百度地图的使用(普通定位、反地理编码)  # 微信小程序 地图定位简单实例  # Android百度地图实现搜索和定位及自定义图标绘制并点击时弹出泡泡  # nodejs根据ip数组在百度地图中进行定位  # 所处  # 默认为  # 多久  # 不限时  # 你要  # 很简单  # 做个  # 几步  # 绑定  # 输入框  # 器中  # ng  # qu  # shi  # br  # jiedao  # model  # js  # var  # getAddr 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  奇安信“盘古石”团队突破 iOS 26.1 提权  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  如何用VPS主机快速搭建个人网站?  lovemo网页版地址 lovemo官网手机登录  青岛网站建设如何选择本地服务器?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  Laravel如何实现数据库事务?(DB Facade示例)  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践  简单实现jsp分页  大型企业网站制作流程,做网站需要注册公司吗?  Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用  Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  如何快速启动建站代理加盟业务?  如何用美橙互联一键搭建多站合一网站?  如何在腾讯云服务器上快速搭建个人网站?  如何挑选最适合建站的高性能VPS主机?  免费网站制作appp,免费制作app哪个平台好?  PHP 500报错的快速解决方法  UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】  Laravel Admin后台管理框架推荐_Laravel快速开发后台工具  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  Laravel怎么使用Blade模板引擎_Laravel模板继承与Component组件复用【手册】  如何在IIS7中新建站点?详细步骤解析  郑州企业网站制作公司,郑州招聘网站有哪些?  Python文件操作最佳实践_稳定性说明【指导】  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  Laravel怎么实现模型属性的自动加密  网站建设整体流程解析,建站其实很容易!  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  Laravel如何优雅地处理服务层_在Laravel中使用Service层和Repository层  Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】  如何在云主机上快速搭建多站点网站?  Laravel API资源类怎么用_Laravel API Resource数据转换  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  Laravel如何使用Eloquent进行子查询  如何快速上传建站程序避免常见错误?  Laravel storage目录权限问题_Laravel文件写入权限设置  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  图册素材网站设计制作软件,图册的导出方式有几种?  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程