0

0

网页怎么嵌入百度地图_第三方API接入教程【详解】

星夢妙者

星夢妙者

发布时间:2026-02-12 20:11:47

|

485人浏览过

|

来源于php中文网

原创

百度地图js api已停用新账号注册且限频,常见报错“bmap is not defined”源于sdk未加载或ak无效;地理编码接口不可靠,容器空白多因css宽高缺失或隐藏导致。

网页怎么嵌入百度地图_第三方api接入教程【详解】

百度地图 JavaScript API 不再开放新账号注册,2023 年起全面停用密钥申请服务。你现在无法通过官方渠道获取新的 ak(Access Key),旧 ak 也仅限存量项目维持调用,且部分接口(如地理编码、路线规划)已限频或返回空数据。

为什么 initMap 报错 “BMap is not defined”

这是最常见现象,本质是 SDK 加载失败或时机错误:

  • 未在 HTML 中正确引入百度地图 JS 文件——必须使用 https://api.map.baidu.com/api?v=3.0&ak=YOUR_AK,注意 v=3.0 是当前唯一可用版本,v=2.0 已下线
  • ak 无效或过期:控制台会报 INVALID_REQUESTKEY_EXPIRED,但脚本仍会加载,只是后续所有 API 调用静默失败
  • 地图初始化代码执行早于 SDK 加载完成:不能直接写 initMap(),必须等 window.BMap 存在或监听 load 事件

推荐写法:

<script src="https://api.map.baidu.com/api?v=3.0&ak=your_ak_here"></script>
<script>
window.initMap = function() {
  if (!window.BMap) return;
  const map = new BMap.Map("container");
  map.centerAndZoom(new BMap.Point(116.404, 39.915), 15);
};
// 确保 DOM 就绪 + SDK 就绪
document.addEventListener('DOMContentLoaded', () => {
  if (window.BMap) initMap();
  else setTimeout(() => window.initMap && initMap(), 500);
});
</script>

BMap.Geocoder 返回空结果或 status: 1

地理编码(地址转坐标)接口实际已不可靠,status: 1 表示“服务器内部错误”,不是你参数问题:

狸谱App
狸谱App

AI壁纸漫画梗图,年轻人的抽象创作社区

下载
  • 百度对非白名单域名的 geocoding/v3/ 接口做了严格 referer 校验,即使 ak 正确也会拦截
  • 返回 {status: 0, result: []} 很可能是地址格式不规范,比如含空格、全角字符、省市区层级缺失(必须写“北京市朝阳区建国路87号”,不能只写“建国路87号”)
  • 替代方案更现实:改用高德 Web API(需注册,但目前开放新账号)、或本地缓存常用地址的坐标(如城市中心点),避免实时请求

地图容器显示空白但无报错

这通常不是 API 问题,而是 CSS 或 DOM 渲染导致:

  • <div id="container"></div> 没设宽高:百度地图要求容器有明确像素尺寸,height: 100% 无效,必须写 height: 400px 或类似固定值
  • 父级元素被 display: nonevisibility: hidden 隐藏过:地图初始化后若容器曾隐藏,需手动触发 map.centerAndZoom()map.refresh()
  • 页面用了 CSS-in-JS 或 Shadow DOM:BMap 依赖全局 document.body 插入图层,某些框架(如 Vue 3 + ShadowRoot)会导致地图控件渲染到页面外

现在嵌入百度地图真正的难点不在代码,而在 ak 的有效性、接口稳定性与政策合规性。如果你的项目刚启动,优先评估是否真的需要百度地图——多数场景下,用静态图(https://api.map.baidu.com/staticimage?)+ 坐标预存,比硬扛 JS API 更省心。

相关文章

百度地图
百度地图

百度地图作为新一代人工智能地图,服务覆盖全球200+城市及国家。导航可信赖、语音交互更简单、数据丰富更贴心的百度地图,致力于为用户提供更准确、更丰富、更易用的出行服务。有需要的小伙伴快来保存下载体验吧!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1393

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

319

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2209

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

36

2026.01.19

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

64

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

44

2025.11.27

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

4

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 3.6万人学习

golang和swoole核心底层分析
golang和swoole核心底层分析

共3课时 | 0.2万人学习

Python 并发编程实战
Python 并发编程实战

共12课时 | 0.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号