dedecms百度地图接入 地理位置标注

DEDECMS中实现地理位置标注,核心在于数据存储与前端展示。1. 数据存储方面:需为内容模型添加三个自定义字段,分别为经度(map_lng)、纬度(map_lat)和地址描述(map_address),类型通常为“单行文本”或“多行文本”,并在发布或编辑内容时手动填写或通过地图选点工具自动填充。2. 前端展示方面:需引入百度地图api脚本并创建地图容器,在模板中使用JavaScript初始化地图,读取dedecms字段中的经纬度数据,并添加标记及信息窗口,同时建议加入判断逻辑处理空值情况以提升用户体验。3. 提升后台编辑效率方面:可通过修改后台模板文件,在编辑页面嵌入百度地图实例,并编写JS代码实现点击地图自动获取坐标并填充至输入框,进一步优化数据录入流程。

dedecms百度地图接入 地理位置标注

在DedeCMS里给内容加上地理位置标注,核心思路就是把百度地图的经纬度数据和你的文章、产品或其他内容关联起来,然后在前端页面上调用百度地图API,把这些点位可视化地展示出来。这事儿听起来有点技术含量,但其实只要理清思路,一步步来,并不算太复杂。关键在于数据怎么存,以及前端怎么把存好的数据显示出来。

解决方案

要在DedeCMS中实现百度地图的地理位置标注,主要分为数据存储和前端展示两个环节。

数据存储(DedeCMS后台): 你需要在DedeCMS的后台为你的内容模型(比如文章模型、产品模型或自定义模型)添加新的自定义字段,用来存储地理位置信息。通常,我们会添加至少三个字段:

  1. 经度 (Longitude): 比如字段名 map_lng,类型选择“单行文本”。
  2. 纬度 (Latitude): 比如字段名 map_lat,类型选择“单行文本”。
  3. 地址名称/描述 (Address Name/Description): 比如字段名 map_address,类型选择“单行文本”或“多行文本”,用于显示地址文字说明。

这些字段添加完成后,在你发布或编辑内容时,就可以手动填写对应的经纬度和地址信息了。如果你想更省事,也可以在后台表单里嵌入一个小的百度地图选点工具,通过点击地图自动填充经纬度,但这需要对DedeCMS的后台模板做一些二次开发

前端展示(DedeCMS模板): 在DedeCMS的前端模板(通常是article_article.htm或你自定义模型的模板文件)中,你需要引入百度地图的JavaScript API,并编写相应的代码来读取你刚才存储的经纬度数据,然后在地图上进行标注。

  1. 引入百度地图API: 在head标签内或body结束标签前引入API脚本,记得替换成你的ak(Access Key)。

    <script type="text/javascript" src="https://api.map.baidu.com/api?v=3.0&ak=你的百度地图AK"></script>
  2. 创建地图容器: 在你希望显示地图的地方,添加一个div元素作为地图的容器,并给它一个ID。

    <div id="allmap" style="width: 100%; height: 400px;"></div>
  3. 初始化地图并添加标注: 编写JavaScript代码来初始化地图,并获取DedeCMS字段中的经纬度数据,然后添加标记。

    <script type="text/javascript">     // 获取DedeCMS字段中的经纬度     var lng = "{dede:field.map_lng /}"; // 假设你的经度字段名为map_lng     var lat = "{dede:field.map_lat /}"; // 假设你的纬度字段名为map_lat     var address = "{dede:field.map_address /}"; // 假设你的地址字段名为map_address      if (lng && lat) {         var map = new BMap.Map("allmap");    // 创建地图实例         var point = new BMap.Point(lng, lat); // 创建点坐标         map.centerAndZoom(point, 15);        // 初始化地图,设置中心点和缩放级别         map.enableScrollWheelZoom(true);     // 开启鼠标滚轮缩放          var marker = new BMap.Marker(point);  // 创建标注         map.addOverlay(marker);               // 将标注添加到地图中          // 添加信息窗口         if (address) {             var infoWindow = new BMap.InfoWindow(address, {                 width : 200,     // 信息窗口宽度                 height: 50,      // 信息窗口高度                 title : "位置信息" // 信息窗口标题             });             marker.addEventListener("click", function(){                 this.openInfoWindow(infoWindow);             });             // 也可以选择地图加载后直接打开信息窗口             // map.openInfoWindow(infoWindow, point);         }     } else {         // 如果没有经纬度数据,可以隐藏地图容器或显示提示         document.getElementById('allmap').style.display = 'none';         // 或者显示一个提示:         // document.getElementById('allmap').innerhtml = '<p>暂无地理位置信息。</p>';     } </script>

    确保你的ak是有效的,并且经纬度数据是正确的数字格式。

DedeCMS中如何创建并管理地理位置相关的自定义字段?

在DedeCMS里处理地理位置信息,第一步也是最基础的一步,就是给你的内容模型“扩容”,也就是添加自定义字段。这就像是给你的文章、产品表格增加了新的列,专门用来存放经纬度这类数据。

具体操作路径一般是:DedeCMS后台 -> 核心 -> 频道模型 -> 普通文章(或你正在使用的其他模型) -> 字段管理 -> 增加新字段。

创建字段时,有几个点我觉得挺重要的:

  • 字段名称: 建议用英文小写,比如map_lng、map_lat、map_address。这样在模板里调用的时候会很方便,也符合DedeCMS的命名习惯。
  • 字段类型: 经度和纬度通常选择“单行文本”,因为它们就是一串数字。地址描述可以选择“单行文本”或“多行文本”,看你需要的描述长度。
  • 表单提示文字: 这个是给后台编辑人员看的,写得清晰一点,比如“百度地图经度”、“百度地图纬度”、“详细地址描述”,这样大家在录入内容的时候就不会迷茫了。
  • 字段长度: 经纬度一般不需要太长,设个50或100字符足够了。地址描述根据实际情况定。

字段添加成功后,你发布或修改文章时,就会在编辑界面看到这些新加的字段了。对我来说,这一步是整个地理位置标注的基础,没有字段存储数据,后面的一切都无从谈起。虽然手动输入经纬度有点麻烦,但这是最直接、最不需要额外开发的方式。

百度地图API接入时,前端模板需要哪些关键代码和配置?

前端模板的配置,可以说直接决定了你的地图能不能正常显示,以及显示得好不好看。我个人觉得,最重要的就是API的引入和地图的初始化,这两块是基石。

  1. 获取Access Key (AK): 这是你使用百度地图API的“通行证”。你需要在百度地图开放平台注册账号,创建应用,然后就能拿到一个AK。这个AK是唯一的,也是非常关键的。没有它,API是无法正常工作的。
  2. API脚本引入: 就像前面解决方案里提到的,你需要把百度地图的JS API文件引入到你的HTML页面中。通常放在标签里或者标签结束前。
    <script type="text/javascript" src="https://api.map.baidu.com/api?v=3.0&ak=你的百度地图AK"></script>

    这里v=3.0指定了API的版本,ak=你的百度地图AK就是你从开放平台申请到的密钥。

  3. 地图容器: 页面上必须有一个div元素作为地图的载体。这个div需要有固定的id,并且最好设置好宽度和高度,否则地图可能不会显示或者显示不全。
    <div id="allmap" style="width: 100%; height: 400px;"></div>

    这个id(比如allmap)会在JS代码中用到,用来告诉百度地图在哪里渲染。

  4. 地图初始化和标注逻辑: 这是核心的JavaScript代码。你需要:
    • 创建地图实例: var map = new BMap.Map(“allmap”);
    • 创建点坐标: var point = new BMap.Point(lng, lat); 这里lng和lat就是从DedeCMS字段里取出来的经纬度。
    • 设置中心点和缩放级别: map.centerAndZoom(point, 15); 缩放级别(1-19)决定了地图的视野范围,15通常能看到比较详细的周边环境。
    • 添加控件(可选但常用): 比如map.addControl(new BMap.NavigationControl());(平移缩放控件)、map.addControl(new BMap.ScaleControl());(比例尺控件)。
    • 创建并添加标注: var marker = new BMap.Marker(point); map.addOverlay(marker);
    • 添加信息窗口(可选): 如果想点击标注弹出地址信息,就需要创建BMap.InfoWindow并绑定到marker的click事件上。

实际操作中,我发现一个常见的“坑”就是经纬度数据格式不对或者为空。DedeCMS字段取出来的值,有时候可能是空字符串。所以,在JS代码里加个判断,确保lng和lat有值再初始化地图,否则就别显示地图了,或者给个提示,这样用户体验会好很多。

如何在DedeCMS后台实现地图选点功能,提升内容编辑效率?

在DedeCMS后台实现地图选点,而不是手动输入经纬度,这确实能极大提升编辑效率,减少出错。这本质上是对DedeCMS后台编辑界面进行二次开发,嵌入一个简易的百度地图选点工具。

我的理解是,这块不是DedeCMS自带的功能,所以你需要动手修改DedeCMS的核心文件或创建自定义插件。通常,我会考虑以下几个步骤来实现:

  1. 找到对应的编辑模板文件: DedeCMS后台发布/修改文章的模板文件通常位于dede/templets/目录下,比如article_add.htm和article_edit.htm(针对普通文章模型),或者你自定义模型的对应文件。你需要修改这些文件,在经纬度输入框附近插入地图选点代码。

  2. 嵌入百度地图实例: 在经纬度输入框(比如你自定义的map_lng和map_lat字段对应的input框)下方,添加一个div作为地图容器,并引入百度地图API。

    <!-- 经度输入框 --> <input type="text" name="map_lng" id="map_lng" value="{dede:field.map_lng /}" /> <!-- 纬度输入框 --> <input type="text" name="map_lat" id="map_lat" value="{dede:field.map_lat /}" />  <!-- 地图容器 --> <div id="backend_map" style="width: 100%; height: 300px; margin-top: 10px; border: 1px solid #ccc;"></div>
  3. 编写JavaScript选点逻辑: 在同一个页面中,编写JavaScript代码。这段代码负责:

    • 初始化后台地图: 创建一个BMap.Map实例,设置一个默认的中心点和缩放级别。

    • 添加点击事件监听: 监听地图的click事件。当用户点击地图时,获取点击点的经纬度。

      var map = new BMap.Map("backend_map"); var point = new BMap.Point(116.404, 39.915); // 默认中心点,比如北京 map.centerAndZoom(point, 12); map.enableScrollWheelZoom(true);  // 创建一个标记,用于显示当前选择的点 var currentMarker = null;  map.addEventListener("click", function(e){     var lng = e.point.lng;     var lat = e.point.lat;      // 将经纬度填充到对应的输入框     document.getElementById('map_lng').value = lng;     document.getElementById('map_lat').value = lat;      // 移除旧的标记(如果有)     if (currentMarker) {         map.removeOverlay(currentMarker);     }     // 添加新的标记     currentMarker = new BMap.Marker(e.point);     map.addOverlay(currentMarker);     map.panTo(e.point); // 平移地图到新选择的点 });
    • 初始加载时显示已有标记: 如果编辑的是已有内容,map_lng和map_lat字段可能已经有值。在地图初始化后,读取这些值并在地图上显示一个初始标记。

这个过程需要你对DedeCMS的文件结构和前端JS有一定了解。虽然有点复杂,但对于那些需要频繁录入地理位置信息的网站来说,投入这点开发成本是非常值得的。毕竟,手动输入经纬度不仅效率低,还容易输错。通过地图直观地点击选择,体验好太多了。

© 版权声明
THE END
喜欢就支持一下吧
点赞7 分享