一、先看效果
![](https://img-blog.csdnimg.cn/9da091db829e4c6d9d56aec6aa4e334b.png)
业务场景就是通过开关来控制经纬线格网图层在地图上的显示与关闭,且开启时,随着地图的移动(视窗发生了改变),网格图层也要相应的实时清除和重绘。这个功能看似简单,实则操作起来还是有很多需要注意的地方:
1、首先你得对leaflet api 有所了解甚至是熟练使用常用的对象和函数;
2、其次你要考虑到Web墨卡托投影下纬度间隔从赤道向两极是逐渐增大的,即越往极地地区,区域面积是被拉伸(变大)的,所以不能按照纬度等分去绘制不同zoom下的格网的,如果这样绘制,效果就像下面这样的,这显然不太符合实际情况。
![](https://img-blog.csdnimg.cn/a8d7d6933a224026a9985b2037c0a362.png)
3、第2条行不通后,你就要考虑使用瓦片格网(每张瓦片都是正方形,距离等分)的方式来绘制,即通过视窗map的bounds来计算出当前zoom下瓦片的row和col值,然后通过gis数学公式反算每个格子的经纬度,经纬度有了后就好办了,直接使用leaflet的api绘制相应的要素图层和标注即可!
4、当然考虑这些是远远不够的,你要做的是一个公共插件(或者称作是模块或组件),那就要符合npm模块的标准,比如怎么构建一个标准的模块项目,怎么配置webpack?怎么编译代码? 怎么打包?怎么推送到npm仓库? 后期怎么更新?如果用了阿里的镜像仓库,却发现别人怎么都拿不到最新推上去的包该怎么办?等等,这些问题你都要轻车熟路。而整个npm模块包的构建和推送是有一套流程的,比如像下面这种我整理的:
![](https://img-blog.csdnimg.cn/2845ae1c222b46119b89478951bec27f.png)
5、知道了怎么构建npm模块包后,你最后要做的就是编写好代码,让别人在自己的项目中下载了你的插件后,只需要简单引入一下依赖,简单敲几行代码就可以实现他们想要的功能。这种简单背后的工作是大量的代码封装,即你要把变化的东西全部封装起来(变化的部分可提供默认值),然后将变化的属性通过API方法的形式暴露给调用方,由调用方很灵活的去设置以达到他们想要的绘制效果。比如经纬线的颜色、宽度等,经纬(度数值)标注的颜色和字体大小等,以及标注显示的方位等。我们将其封装到具体的实现(绘制插件)类中,然后通过下面的方式让使用者去用:
![](https://img-blog.csdnimg.cn/68f999342ca14ab6ac8f6c60fe1c097d.png)
![](https://img-blog.csdnimg.cn/b4d743dc2b804141bd0b999a73743b14.png)
二、编写插件
核心插件类如下:
![](https://img-blog.csdnimg.cn/347db40e5fb24b9bbf56d1f1dda0851b.png)
核心脚本如下:
![](https://img-blog.csdnimg.cn/fcfeb558be264aa4b90a3817395ac422.png)
三、编写插件测试案例
配置开发环境下的webpack5
![](https://img-blog.csdnimg.cn/6d9bfdec937a4df48e57ddcf1368488e.png)
借助react在public目录下编写测试用例以检验插件功能是否可用
![](https://img-blog.csdnimg.cn/d4d84ed0b5ed4adf9e35ca33b73d6a6a.png)
使用默认参数的效果
![](https://img-blog.csdnimg.cn/92133da4ce0d4ade877dfa4c513ca9d6.png)
使用自定义参数的效果(插件随时可以基于业务需要进行升级迭代,暴露出更多api出来)
![](https://img-blog.csdnimg.cn/a9326991bf494f75b64cc6280708a2f1.png)
四、推送包到NPM公仓
推送成功之后,任何人都可以基于keywords在npm全库中搜索到我们的插件信息
![](https://img-blog.csdnimg.cn/46c953a4c20442a39df2daccda2a5a88.png)
![](https://img-blog.csdnimg.cn/768f1e8fe95e41598bc7e2db7ea3c036.png)
![](https://img-blog.csdnimg.cn/0c64defae6644974a15f0deb4a2ea987.png)
等等..... ..... .....
五、如何使用该插件?
具体怎么用,可以参考Gitee:https://gitee.com/appleyk/leaflet-lonlat-gridlines-test
![](https://img-blog.csdnimg.cn/3f0aa30c168b4d899ba7b2566a4c4e7e.png)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)