百度地图marker无法添加右键菜单

发布于 2022-09-04 09:53:49 字数 2488 浏览 24 评论 0

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

<html>
<head>
<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.4"></script>
</head>
<body>
    <div id="container"></div>
        <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(("查看坐标"), function () {
                    alert("hello");
                }));
                marker.addContextMenu(contextMenu);
            }
        </script>
</body>
</html>

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

<html>
<head>
<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.4"></script>
</head>
<body>
    <div id="container"></div>
        <script type="text/javascript">
            //初始化地图
            var map = new BMap.Map("container");
            var point = new BMap.Point(100, 100);
            map.centerAndZoom(point, 17);
            //直接添加marker
            var point = new BMap.Point(100, 100);
            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(("查看坐标"), function () {
                    alert("hello");
                }));
                marker.addContextMenu(contextMenu);
            }
        </script>
</body>
</html>

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

绝不服输 2022-09-11 09:53:49

使用 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>
    <div id="container"></div>
    <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>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文