微信小程序地图标记点,安卓手机一次性渲染不出来的问题

问题描述:

如果微信小程序端,渲染的标记物太多,安卓手机存在标记物不显示的问题,原因初步判断是地图还没有渲染完,标记物数据已经加载完了,导致没有在地图上显示。

解决办法:

使用map组件的bindupdated="onUpdated"方法监听地图渲染完成,这个时候,再去渲染标记物,而且还得多次渲染,如果覆盖物图片多了,一次还不够。所以我遍历了5次

javascript 复制代码
// 监听地图渲染完成
    onUpdated(e) {
        console.log('onRegionChange', e)
        for (let i = 0; i < 5; i++) {
            this.timer = setTimeout(() => {
                let markers = this.data.markers
                this.setData({
                    coverMarkers: markers
                });
            }, 1000 * i)
        }
    },

但是,千万注意,map上的标记物变量,不要自定义标记物变量使用同一个,否则你每次更新【自定义标记物变量】,就会导致onUpdated再次被触发,进入死循环,所以,这两个字段,虽然值一样,但是要分成两个,例如:

javascript 复制代码
data: {
        markers: [],//地图标记
        coverMarkers: [],//覆盖物标记
        currentLocation: {
            latitude: '',
            longitude: ''
        },
        scale: 16  // 添加缩放级别
    },

最后,地图标记坐标+自定义标记物:

javascript 复制代码
<map id="map" 
            longitude="{{currentLocation.longitude}}" 
            latitude="{{currentLocation.latitude}}" 
            scale="{{scale}}"
            markers="{{markers}}" 
            show-location 
            bindupdated="onUpdated"
            bindcallouttap="handleCalloutTap" 
            style="width: 100%; height: 300px;">
            <view slot="callout">
                <cover-view wx:for="{{coverMarkers}}" wx:key="id">
                <cover-view class="marker-container" marker-id="{{item.id}}" wx:if="{{item.customCallout}}">
                    <cover-view class="customCallout" style="background: {{item.bgColor}}">
                        <map-callout marker="{{item}}"/>
                    </cover-view>
                </cover-view>
            </cover-view>
            </view>
        </map>

这是我总结的解决办法,如果你有好的解决方法,辛苦告诉我一下

相关推荐
烂不烂问厨房6 小时前
支付宝小程序camera录制视频并上传注意事项
小程序·音视频
PeanutSplsh6 小时前
wx.setStorage 存的数据,没你以为的那么安全
微信小程序
我是伪码农9 小时前
小程序125-150
小程序
帅次9 小时前
讯飞与腾讯云:Android 实时语音识别服务对比选择
android·ios·微信小程序·小程序·android studio·android runtime
Chengbei1110 小时前
小程序 AI 渗透新工具MCP!打通调试与安全检测、网络抓包、接口分析、越权检测一站式实现
人工智能·安全·web安全·搜索引擎·网络安全·小程序·系统安全
2501_9159090612 小时前
深入理解HTTPS中间人抓包技术原理与实战指南
网络协议·http·ios·小程序·https·uni-app·iphone
he___H12 小时前
微信小程序实现两行交错功能
微信小程序·小程序
前端小木屋1 天前
uniapp与蓝牙设备连接详细步骤
前端·微信小程序
万岳科技系统开发1 天前
私域直播系统开发从0到1:企业直播平台搭建全过程
前端·小程序·架构
2501_916007471 天前
iOS应用性能优化全面指南:从内存管理到工具使用
android·ios·性能优化·小程序·uni-app·iphone·webview