使用uniapp的nvue开发地图map功能踩坑记录

nvue(native vue 的缩写)官网介绍

前言

由于这个app项目立项时间很紧,没有时间做技术预研就选了uniapp,地图又是首要功能而且是首页,所以一步一个坑了属于是。
当项目中有使用mapvideolive-pusher等组件且属于主要功能时,非必要不要用uniapp !

踩坑1:开发app时不要用vue写map

之前用vue写过几个前端map功能,本以为uniapp写app也大差不差用vue就行,于是让同事先把首页另一半非地图的UI先写了,留出map容器位置。

结果开始写map的时候发现运行到app后效果和网页完全不同,然后才翻了uniapp的文档发现需要用nvue。那就直接改文件后缀.vue转.nvue,结果样式完全错乱(文档有写很多css样式nvue不支持),乱到Cursor都拯救不了只能重写布局。

踩坑2:map的markers属性限制很多

具体请参考官网map组件介绍

我先说我遇到的一个问题。我用Cursor写代码,运行到iPhone模拟器上看效果,在写地图自定义marker时自动生成了以下代码:

js 复制代码
mapMarkers.value = [
      {
        ...省略,
        customCallout: {
          display: 'ALWAYS',
          anchorX: 0,
          anchorY: 20,
        },
      },
]

其中设置了偏移量anchorY,运行到iPhone模拟器和真机上后效果都没有问题,然后开心的写完了功能,然后Android同事说运行到Android上后没有偏移量。

调试了半天后发现文档里customCallout仅仅支持设置display这个属性。咱就是说,uniapp能不能起码保持下iOS、Android两端统一性啊?或者像下面display的说明一样写在文档里。

相关推荐
天天摸鱼的java工程师1 分钟前
凌晨四点,掘金签到 bug 现场抓包,开发同学速来认领!
服务器·前端·后端
橙某人19 分钟前
🤖Agent进化论:从Copilot到主驾驶,MCP如何成为AI的"万能接口"?
前端·mcp
刺客-Andy33 分钟前
React 第五十一节 Router中useOutletContext的使用详解及注意事项
前端·javascript·react.js
NoneCoder36 分钟前
React进阶:状态管理选择题
前端·react.js·面试
巴巴_羊37 分钟前
react 生命周期
前端·react.js·前端框架
刺客-Andy37 分钟前
React 第五十二节 Router中 useResolvedPath使用详解和注意事项示例
前端·javascript·react.js
datascome40 分钟前
简数采集技巧之快速获取特殊链接网址URL方法
前端·经验分享·爬虫·程序人生·正则表达式
架构个驾驾43 分钟前
Vue2 与 Vuex 状态管理实战指南
前端·javascript·vue.js
贵州数擎科技有限公司44 分钟前
Unity 单例模式完全指南
前端