1. 引言

uniapp中自带有map组件,并且自带的map组件有常见的显示地图、绘制点线面的功能

但是,它存在以下问题:

  • 收费,自带的map组件使用的是高德、腾讯的地图,无论使用什么样的功能,即使只是绘制底图,也无论多少人使用,需要收费
  • 可定制能力低,除了map组件提供的方法与属性以外,难以加入其他的方法

所以,如果能引入专业的地图库(GIS库),那自然是一个好选择

Web地图库(即WebGIS库)常用的有Leaflet、OpenLayers等,Leaflet非常轻量,所以笔者这里选择了这个库

这里还要回答一个问题,uniapp是否支持引入第三方库,尤其是这种需要显示出来的第三方库?

答案是可以,uniapp使用renderjs实现了在视图层操作dom,运行 for web 的 js库,具体可参考:renderjs | uni-app官网 (dcloud.net.cn)

2. 引入Leaflet

uniapp支持使用npm安装的node_modules,但是不能直接在项目文件夹下使用npm install <xxx>

所以,需要在一个空文件夹下使用npm install leaflet,然后再将node_modules下的文件夹复制到uniapp的项目文件夹下

(笔者注:这真是个费解的过程,可以理解为uniapp只是支持搜索node_modules下库,但是不支持npm管理方式)

现在项目的目录结构如下:

3. 创建一个map页面

现在创建一个地图页面,它的结构大致如下:

<template>
<view>
<!-- 这个view用于显示地图 -->
<view id="map" class="map"></view> <!-- 这个view用于数据通信 -->
<!-- 监听变量 mapData 的变化,mapData 发生改变时,调用 leaflet 模块的 reciveMessage 方法 -->
<view :mapData="mapData" :change:mapData="leaflet.reciveMessage"></view>
<!-- mapData、reciveMessage这些名字可以自定义,但是大致结构如此 -->
</view>
</template> <script>
// vue代码
</script> <script module="leaflet" lang="renderjs">
// module名可以自定义,但lang得是renderjs import "leaflet/dist/leaflet.css"
import L from "leaflet" // Leaflet操作代码
</script> <style lang="scss" scoped>
// 样式代码
</style>

4. 示例代码

笔者这里的示例代码如下,实现了根据传入的数据绘制图形:

<template>
<view>
<nav-bar title="查看地图 "></nav-bar>
<view id="map" class="map"></view>
<!-- 监听变量 mapData 的变化,mapData 发生改变时,调用 leaflet 模块的 reciveMessage 方法 -->
<view :mapData="mapData" :change:mapData="leaflet.reciveMessage"></view>
</view>
</template> <script>
export default {
data() {
return {
mapData: null
}
},
onLoad(opt) {
try {
this.mapData = JSON.parse(opt.mapData)
} catch (e) {
console.error("数据解析错误:", e)
}
},
methods: {
/**
* 接收 renderjs 传过来的数据
* @param {Object} data
*/
reciveMessage: function(data) {
console.log(data)
this.mapData = data
}
}
}
</script> <script module="leaflet" lang="renderjs">
import "leaflet/dist/leaflet.css"
import L from "leaflet" let map = null export default {
data() {
return {
mapData: null
}
},
mounted() {
map = L.map('map', {
center: [36.262131, 120.356609],
zoom: 12,
minZoom: 4,
maxZoom: 18,
zoomControl: false,
attributionControl: false
}) L.tileLayer('http://t0.tianditu.com/DataServer?T=img_w&x={x}&y={y}&l={z}&tk=9813be7882272b227babab98c39a64b6').addTo(map) this.sendMsg()
},
methods: {
sendMsg() {
// 向页面传参
this.$ownerInstance.callMethod('reciveMessage', this.mapData)
},
reciveMessage(newValue, oldValue, ownerInstance, instance) {
this.mapData = newValue
this.drawMap(newValue)
},
drawMap(data){ console.log(data) if(!data || !map) return switch(data.type){
case "circle":
L.circle(data.center, { radius: data.radius }).addTo(map)
break
case "polygon":
L.polygon(data.positions).addTo(map)
break
case "point":
L.circle(L.latLng(data.x, data.y), { weight: 10 , color: "#f00" }).addTo(map)
break
case "polyline":
L.polyline(data.positions).addTo(map)
break
}
}
}
}
</script> <style lang="scss" scoped>
.map {
width: 100%;
height: 100vh;
}
</style>

结果图如下:

5. 参考资料

[1] renderjs | uni-app官网 (dcloud.net.cn)

[2] uniApp中使用leaflet地图组件踩坑记 - 掘金 (juejin.cn)

uniapp中引入Leaflet的更多相关文章

  1. 在HbuilderX的Uni-app中引入crypto-js md5

    在 hbuilderX的菜单“视图”中选择“显示终端”,在终端中把当前目录定位到uni-app的根目录,这样才可以把crypto-js库安装在正确的位置,在终端中键入:npm install cryp ...

  2. uniapp中引入less文件

    uniapp入门遇到的问题记录 在uniapp中从外部import less文件的话,首先需要在 工具>插件安装 中安装支持less语法的插件,然后在.vue文件中引入  @import url ...

  3. VUE2 项目 引入 leaflet.draw全过程

    leaflet.draw的参考文档:http://leaflet.github.io/Leaflet.draw/docs/leaflet-draw-latest.html   这个网址不稳定,多刷新几 ...

  4. uni-app中页面部分内容使用索引列表(uni-indexed-list),动态数据

    一.引入uni-indexed-list.uni-icons组件 从uni-app插件市场下载或从HBuilder X提供的hello uni-app模板中复制 二.页面中引用 三.对请求获得的数据处 ...

  5. uni-app在线引入阿里字体图标库

    第一步 在app.vue中引入阿里字体图标库 第二步 在任意页面使用就可以了 <view class="item" v-for="(value,index) in ...

  6. uni-app中组件的使用

    组件基本知识点: uniapp中:每个页面可以理解为一个单页面组件,这些单页面组件注册在pages.json里,在组件关系中可以看作父组件. 自定义可复用的组件,其结构与单页面组件类似,通常在需要的页 ...

  7. uniapp H5引入腾讯地图

    在网上搜索了许多关于uniapp引入腾讯地图的方法都以失败告终,我开发的应用主要使用于H5,小程序与H5是不同的sdk,就不在这说了,况且小程序有手把手教学,可参考腾讯地图官网https://lbs. ...

  8. uni-app中websocket的使用 断开重连、心跳机制

    前言 最近关于H5和APP的开发中使用到了webSocket,由于web/app有时候会出现网络不稳定或者服务端主动断开,这时候导致消息推送不了的情况,需要客户端进行重连.查阅资料后发现了一个心跳机制 ...

  9. uniapp中vuex的基本使用

    1. 创建一个uniapp项目 2. 在项目目录下用npm安装 vuex npm install vuex --save 3. 在项目根目录下创建 store文件夹,在store文件夹中创建 inde ...

  10. uniapp中拿到base64转blob对象,或base64转bytes字节数组,io操作写入字节流文件bytes

    1. uniAPP中拿到附件的base64如何操作,如word文件 /*** 实现思路:* 通过native.js的io操作创建文件,拿到平台绝对路径* 再通过原生类进行base64解码,拿到字节流b ...

随机推荐

  1. NC200195 区区区间

    题目链接 题目 题目描述 \(Keven\) 特别喜欢线段树,他给你一个长度为 \(n\) 的序列,对序列进行 \(m\) 次操作. 操作有两种: 1 \(1\ l\ r\ k\) :表示将下标在 \ ...

  2. Spring Boot图书管理系统项目实战-5.读者管理

    导航: pre:  4.基础信息管理 next:6.图书管理 只挑重点的讲,具体的请看项目源码. 1.项目源码 需要源码的朋友,请捐赠任意金额后留下邮箱发送:) 2.页面设计 <!DOCTYPE ...

  3. 责任链模式与spring容器的搭配应用

    背景 有个需求,原先只涉及到一种A情况设备的筛选,每次筛选会经过多个流程,比如先a功能,a功能通过再筛选b功能,然后再筛选c功能,以此类推.现在新增了另外一种B情况的筛选,B情况同样需要A情况的筛选流 ...

  4. 列表相关函数,深浅拷贝,字典相关函数,集合相关操作及文件操作---day08

    1.列表的相关函数 append() 功能:向列表的末尾添加新的元素 格式:列表.append(值) 返回值:None 注意:新添加的值在列表的末尾,该函数直接操作原有列表 insert() 功能:在 ...

  5. abc模块的用法

    首先需要了解的是一个基类(父类),abc.ABCMeta.这个是用于实现抽象类的一个基础类 抽象方法的使用,在相应的方法之前一行加上@abstractmethod之后,从新的一行开始定义相应的方法.实 ...

  6. ASP.NET Core 跨域

    跨域常见问题: 1.发布到IIS上后跨域问题 解决方法 修改web.config文件 <system.webServer> <httpProtocol> <customH ...

  7. 【Azure 存储服务】ADLS Gen 2 Backup/软删除/Version管理/快照等功能参考资料

    问题描述 ADLS Gen 2 存储的备份,软删除和version管理, 快照等功能应该怎么启用? 问题回答 存储的备份 测试显示 Premium 定价层 的 ADLS Gen 2 在中国区Azure ...

  8. RocketMQ—RocketMQ集成SpringBoot

    RocketMQ-RocketMQ集成SpringBoot 新建生产者的boot项目和消费者的boot项目,pom文件重点如下: <dependencies> <dependency ...

  9. 代码随想录算法训练营第十三天| 239. 滑动窗口最大值 347.前 K 个高频元素 总结

    239. 滑动窗口最大值 (一刷至少需要理解思路) 卡哥建议:之前讲的都是栈的应用,这次该是队列的应用了.本题算比较有难度的,需要自己去构造单调队列,建议先看视频来理解. 题目链接/文章讲解/视频讲解 ...

  10. 9、zookeeper的核心ZAB协议

    ZAB协议 zab协议的全称是 Zookeeper Atomic Broadcast (zookeeper原子广播).zookeeper是通过zab协议来保证分布式事务的最终一致性 1.ZAB协议是专 ...