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生产环境部署流程

