javascript - 百度地图marker无法添加右键菜单
大家讲道理
大家讲道理 2017-04-11 11:17:14
[JavaScript讨论组]

通过地图的右键菜单添加marker,然后给marker添加右键菜单,marker的右键菜单无法显示。
代码如下:






    

但是如下直接添加marker,然后给marker添加右键菜单,marker的右键菜单就能显示了。
代码如下:






    

如果我想通过右键菜单添加marker,然后给marker添加右键菜单应该怎么做?

大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

全部回复(1)
高洛峰

使用 api?v=2.0 你的第一段代码,是没有问题,可以显示出 marker 的右键菜单。api?v=1.4 的确出不来。没有深究原因。

<html>

<head>
    <script src="https://api.map.baidu.com/api?v=2.0&ak=xxxxxxxx"></script>
    <style>
        #container {
            width: 500px;
            height: 500px;
        }
    </style>
</head>

<body>
    <p id="container"></p>
    <script type="text/javascript">
        //初始化地图
        var map = new BMap.Map("container");
        var point = new BMap.Point(100, 100);
        map.centerAndZoom(point, 17);
        //地图添加右键菜单
        var contextMenu = new BMap.ContextMenu();
        contextMenu.addItem(new BMap.MenuItem(("地图的右键菜单>添加标识"), addMarkerOnMap));
        map.addContextMenu(contextMenu);
        //地图上添加marker函数
        function addMarkerOnMap(e) {
            var point = new BMap.Point(e.lng, e.lat);
            var marker = new BMap.Marker(point);
            map.addOverlay(marker);
            addMarkerContextMenu(marker);
        }
        //marker添加右键菜单函数
        function addMarkerContextMenu(marker) {
            var contextMenu = new BMap.ContextMenu();
            contextMenu.addItem(new BMap.MenuItem(("marker 的右键菜单>查看坐标"), function () {
                alert("hello");
            }));
            marker.addContextMenu(contextMenu);
        }
    </script>
</body>

</html>
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号