2023-09-19 html动态加载百度地图的ak

<!DOCTYPE html>
<html lang="en" style="height: 100%;width: 100%;margin: 0;padding: 0;">
    <head>
        <meta charset="UTF-8" />
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    </head>
    <body style="height: 100%;width: 100%;margin: 0;padding: 0;">
        <script>
            window.onload = function() {
                // get 请求接口
                function fooGet() {
                    let url = ''
                    //第一步:建立所需的对象
                    let httpRequest = new XMLHttpRequest()
                    //第二步:打开连接  将请求参数写在url中
                    httpRequest.open('GET', url, true)
                    //第三步:发送请求  将请求参数写在URL中
                    httpRequest.send()

                    httpRequest.onreadystatechange = function() {
                        if (httpRequest.readyState === 4 && httpRequest.status === 200) {
                            var res = JSON.parse(httpRequest.responseText) //获取到json字符串,还需解析
                            if (res.isSuccess) {
                                // console.log(res.data.jsKey)
                                baiduKEY(res.data.jsKey)
                            }
                        }
                    }
                }
                fooGet()
            }
            function baiduKEY(akData) {
                window.BMap_loadScriptTime = new Date().getTime()
                const BMap_URL = 'https://api.map.baidu.com/getscript?v=3.0&ak=' + akData
                document.write('<div id="b-map" style="height: 100%"></div><script type="text/javascript" src="' + BMap_URL + '"><\/script>')
            }
        </script>
    </body>
</html>

vue 页面嵌套 iframe 使用百度地图

<template>
    <iframe class="b-map" :src="`${prefix}/map.html`" scrolling="no" ref="map"></iframe>
</template>

map.vue

<template>
    <iframe class="b-map" :src="`${prefix}/map.html`" scrolling="no" ref="map"></iframe>
</template>
<script>
export default {
    props: {
        page: String,
        buildingProjectFlag: Boolean
    },
    data() {
        const isload = location.hostname === 'localhost'
        return {
            zoom: 5,
            prefix: isload ? '' : '/roc-component-workbench',
            // baiduAk: ''
            // markerRed: require('@/assets/img/mark-red.png'),
            // markerBlue: require('@/assets/img/mark-blue.png')
        }
    },
    computed: {
        randomId() {
            return Math.floor(Math.random() * (999999 - 100000) + 100000);
        }
    },
    created() {
    },
    mounted() {

        const _this = this
        setTimeout(() => {
            _this.initMap(_this.$refs.map)
            _this.drawMap()
        }, 500);

        this.hook = 'mounted'
    },
    activated() {
        this.hook = 'activated'
        const _this = this
        setTimeout(() => {
            _this.initMap(_this.$refs.map)
            _this.drawMap()
        }, 500);
        if (!this.hasMap) {
            this.$emit('load', 'mounted')
        }
    },
    deactivated() {
        if (this.map) {
            this.isload = false
            this.map = null
        }
    },
    beforeDestroy() {
        if (this.map) {
            this.isload = false
            this.map = null
        }
    },
    methods: {
        // 初始化地图
        initMap(iframe = {}) {
            // 异步加载百度地图
            this.mapReady = new Promise((resolve, reject) => {
                const target = iframe.contentWindow || window
                if (target.BMap) {
                    this.hasMap = true
                    resolve(target.BMap)
                    return
                }
                iframe.onload = function () {
                    this.hasMap = true
                    resolve(target.BMap)
                }
            })
            // 获取已有的map对象
            this.getMap = (function () {
                var map = null
                var BMap = null
                return function (dom, cb, errFn) {
                    if (!map) {
                        this.mapReady.then(bmap => {
                            if (dom.nodeName === 'IFRAME') {
                                const doc = dom.contentWindow.document
                                let el = doc.querySelector('#b-map');
                                if (!el) {
                                    el = doc.createElement('div')
                                    el.setAttribute('id', 'b-map')
                                    el.setAttribute('style', 'height: 100%')
                                    doc.body.appendChild(el);
                                }
                                map = new bmap.Map(el)
                            } else {
                                map = new bmap.Map(dom)
                            }

                            BMap = bmap

                            cb({ map, BMap })

                        }).catch(err => {
                            console.log(err, 84)
                            if (errFn) {
                                errFn()
                            }
                        })
                    } else {
                        cb({ map, BMap })
                    }
                }
            })()
        },
        //地图事件设置函数:
        setMapEvent(map) {
            map.enableDragging();//启用地图拖拽事件,默认启用(可不写)
            map.enableScrollWheelZoom();//启用地图滚轮放大缩小
            map.enableDoubleClickZoom();//启用鼠标双击放大,默认启用(可不写)
            map.enableKeyboard();//启用键盘上下左右键移动地图
        },
        // 绘制地图
        drawMap(address) {
            return new Promise((resolve, reject) => {
                this.getMap(this.$refs.map, ({ map, BMap }) => {
                    if (!address) {
                        address = new BMap.Point(116.4035, 39.915)
                    }
                    const topLeftNavigation = new BMap.NavigationControl({ anchor: 2 });  //左下角,添加默认缩放平移控件
                    map.addControl(topLeftNavigation)

                    map.centerAndZoom(address, this.zoom);
                    map.panBy(180, 0)
                    map.enableScrollWheelZoom(true) // 启用滚轮放大缩小,默认禁用
                    map.enableContinuousZoom() // 启用地图惯性拖拽,默认禁用

                    const el = document.querySelector('.home-wrap')
                    map.addEventListener('zoomstart', () => {
                        if (el) el.style.overflow = 'hidden'
                    })
                    map.addEventListener('zoomend', () => {
                        if (el) el.style.overflow = 'auto'
                    })
                    this.map = map
                    this.isload = true
                    resolve({ map, BMap })
                    this.$emit('load', this.hook)
                }, () => { this.$emit('load', 'mounted') })
            })
        },
        resetView(address) {
            this.getMap(this.$refs.map, ({ map, BMap }) => {
                if (!address) {
                    address = new BMap.Point(116.4035, 39.915)
                }
                this.clearOverlays(true)
                setTimeout(() => {
                    map.centerAndZoom(address, this.zoom);
                    map.panBy(180, 0)
                }, 100)
            })
        },
        // 自定义遮盖物
        customOverlay(BMap, mp) {
            // 复杂的自定义覆盖物
            function ComplexCustomOverlay(point, { text, label }) {
                this.point = point;
                this._text = text;
                this._label = label
            }
            ComplexCustomOverlay.prototype = new BMap.Overlay();
            ComplexCustomOverlay.prototype.initialize = function (map) {
                this._map = map;
                const wrap = this._wrap = document.createElement("div");
                wrap.setAttribute('class', 'use-marker')
                const div = this._div = document.createElement("div");
                var _labelEl = this._labelEl = document.createElement("div");
                _labelEl.setAttribute('class', 'use-marker-label')
                _labelEl.style.position = "absolute";
                _labelEl.style.display = "none";
                _labelEl.style.background = "#fff";
                _labelEl.style.padding = "6px 10px";
                _labelEl.style.fontSize = "14px";
                _labelEl.style.position = "absolute";
                _labelEl.style.top = "-8px";
                _labelEl.style.right = "0";
                _labelEl.style.transform = "translateY(-100%)";
                _labelEl.style.whiteSpace = "nowrap";
                _labelEl.style.zIndex = BMap.Overlay.getZIndex(this.point.lat);
                _labelEl.innerHTML = this._label

                wrap.style.position = "absolute";
                wrap.style.width = "33px";
                wrap.style.height = "24px";
                wrap.style.zIndex = BMap.Overlay.getZIndex(this.point.lat);
                div.setAttribute('class', 'use-marker-content')
                // console.log(div);
                div.style.backgroundImage = `url('')`
                div.style.backgroundSize = "100% 100%";
                div.style.backgroundRepeat = "no-repeat";
                div.style.height = "100%";
                div.style.color = "#fff";
                div.style.textAlign = "center";
                div.style.lineHeight = "20px";
                div.style.whiteSpace = "nowrap";
                div.style.cursor = "pointer";
                div.style.fontSize = "12px";
                div.style.userSelect = "none";
                div.style.zIndex = BMap.Overlay.getZIndex(this.point.lat);

                // div.style.backgroundImage = `url(${this._icon})`;
                var span = this._span = document.createElement("span");
                div.appendChild(span);
                wrap.appendChild(div);
                wrap.appendChild(_labelEl);
                span.appendChild(document.createTextNode(this._text));
                const _this = this
                div.onclick = function (e) {
                    e.stopPropagation()
                    e.preventDefault()
                    if (_this.onClick) {
                        _this.onClick(_this)
                    }
                }
                mp.getPanes().labelPane.appendChild(wrap);
                this._wrap.onmouseover = function () {
                    _labelEl.style.display = "block";
                };
                this._wrap.onmouseout = function () {
                    if (wrap.classList.contains('use-active')) {
                        _labelEl.style.display = "block";
                        div.style.backgroundImage = `url('')`
                        // console.log(_labelEl);

                    } else {
                        _labelEl.style.display = "none";
                    }
                };
                return wrap;
            }
            ComplexCustomOverlay.prototype.draw = function () {
                var map = this._map;
                var pixel = map.pointToOverlayPixel(this.point);
                this._wrap.style.left = pixel.x + "px";
                this._wrap.style.top = pixel.y - 30 + "px";
            }
            ComplexCustomOverlay.prototype.setActive = function (bool) {
                if (bool) {
                    this._wrap.classList.add('use-active')
                } else {
                    this._wrap.classList.remove('use-active')
                }
                if (this._wrap.classList.contains('use-active')) {
                    this._labelEl.style.display = "block";
                } else {
                    this._labelEl.style.display = "none";
                }
            }
            return ComplexCustomOverlay
        },
        // 添加标记
        drawMarker(points) {
            // console.log(points)
            const _this = this
            this.getMap(this.$refs.map, ({ map, BMap }) => {

                const ComplexCustomOverlay = this.customOverlay(BMap, map)
                // const img = this.markerRed
                const markers = [];
                points.forEach((item, index) => {
                    // 指定marker标记所在的地理位置
                    const position = new BMap.Point(...item.point)

                    const marker = new ComplexCustomOverlay(position, { text: item.text, label: item.title })
                    // 设置自定义属性content,作为索引用
                    marker.content = item.text
                    if (item.id) {
                        marker.id = item.id
                    }
                    // 添加事件监听函数
                    marker.onClick = function (target) {
                        _this.$emit('map-click', { target })
                    }
                    markers.push(marker)
                })
                _this.markers = markers
                markers.forEach(marker => {
                    // 将标注添加到地图
                    map.addOverlay(marker);
                })
            })
        },
        // 根据坐标点获取marker
        getMarker(point) {
            const { markers } = this
            if (!markers) return
            return new Promise((resolve, reject) => {
                this.getMap(this.$refs.map, ({ BMap }) => {
                    const po = new BMap.Point(...point)
                    for (let i = 0; i < markers.length; i++) {
                        if (po.equals(markers[i].point)) {
                            resolve(markers[i])
                            return
                        }
                    }
                    reject('未找到')
                })
            })
        },
        // 根据序号获取marker
        getMarkerByOrder(order) {
            const { markers } = this
            if (!markers) return
            return new Promise((resolve, reject) => {
                for (let i = 0; i < markers.length; i++) {
                    if (this.buildingProjectFlag) {
                        if (markers[i].id === order) {
                            resolve(markers[i])
                            return
                        }
                    } else {
                        if (markers[i].id === order) {
                            resolve(markers[i])
                            return
                        }
                    }
                }
                reject('未找到')
            })
        },
        // 设置地图坐标标记样式
        // target 要设置样式的标记
        // move 是否将地图中心移动至 target
        setMarkStyle(target, move) {
            console.log('地图标记', target);
            this.getMap(this.$refs.map, ({ map, BMap }) => {
                if (this.target) {
                    // 标记图标
                    this.target.setActive(false)
                }
                if (target) {
                    // 标记图标
                    // this.target.setActive(true)
                    target.setActive(true)
                    this.target = target
                    move && this.panTo(target.point)
                }
            })
        },
        // 逆向地址解析 address 详细地址,city 所在城市
        getPoint(address, city = '') {
            return new Promise((resolve, reject) => {
                this.getMap(this.$refs.map, ({ map, BMap }) => {
                    // 创建地址解析器实例
                    const geo = new BMap.Geocoder();
                    // 将地址解析结果返回
                    geo.getPoint(address, function (point) {
                        if (point) {
                            resolve(point)
                        }
                    }, city);
                })
            })
        },
        // 调整地图视野
        setViewport(boundary) {
            console.log('setViewport')
            return new Promise((resolve, reject) => {
                this.getMap(this.$refs.map, ({ map, BMap }) => {
                    const bd = new BMap.Boundary();
                    bd.get(boundary, function (rs) {
                        const count = rs.boundaries.length; //行政区域的点有多少个
                        if (count === 0) {
                            return;
                        }
                        let pointArray = [];
                        for (let i = 0; i < count; i++) {
                            const ply = new BMap.Polygon(rs.boundaries[i]); //建立多边形覆盖物
                            pointArray = pointArray.concat(ply.getPath());
                        }
                        map.setViewport(pointArray, {
                            margins: [30, 20, 20, 20]
                        });    //调整视野
                    });
                })
            })
        },
        // 改变地图聚焦点
        panTo(point) {
            this.getMap(this.$refs.map, ({ map, BMap }) => {
                if (point) {
                    point = new BMap.Point(point.lat, point.lng)
                }
                map.panTo([point.lat, point.lng])
                // map.zoomIn() //放大一级视图
                // map.setCenter([point.lat, point.lng]);
                map.centerAndZoom(new BMap.Point(point.lat, point.lng), 6)
                map.centerAndZoom(new BMap.Point(point.lat, point.lng), 15)
                // map.zoomIn()
                // map.zoomIn()
            })
        },
        // 清除地图覆盖物
        clearOverlays(doClear = true) {
            return new Promise((resolve, reject) => {
                this.getMap(this.$refs.map, ({ map, BMap }) => {
                    doClear && map.clearOverlays()
                    resolve({ map, BMap })
                })
            })
        },
        // 点亮省/城市区域
        async drawBoundary(area, doClear = false) {
            const { map, BMap } = await this.clearOverlays(doClear)
            if (typeof area === 'string') {
                this.addBoundary({ map, BMap }, area)
            } else if (Array.isArray(area)) {
                for (let i = 0; i < area.length; i++) {
                    this.addBoundary({ map, BMap }, area[i])
                }
            }
        },
        // 添加行政区划
        addBoundary({ map, BMap }, boundary) {
            if (!boundary) return
            const bd = new BMap.Boundary();
            bd.get(boundary, function (rs) {
                console.log('====rs===')
                console.log(rs)
                const count = rs.boundaries.length; //行政区域的点有多少个
                if (count === 0) {
                    console.log('未能获取当前输入行政区域');
                    return;
                }
                let pointArray = [];
                for (let i = 0; i < count; i++) {
                    const ply = new BMap.Polygon(rs.boundaries[i],
                        { strokeWeight: 2, strokeStyle: 'solid', fillColor: "#027AFF", fillOpacity: 0.1, strokeColor: "#027AFF" }); //建立多边形覆盖物
                    map.addOverlay(ply);  //添加覆盖物
                    pointArray = pointArray.concat(ply.getPath());
                }
                // map.setViewport(pointArray);    //调整视野
            });
        },
    }
}
</script>
<style lang="scss" scoped>
.b-map {
    width: 100%;
    height: 100%;
    border: none;
}
</style>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
百度map,百度map API,百度地图 实现百度地图动态搜索、静态地图动态插入 mygw@163.com js 内容如下: /** 地图的主控类 */ var MapControl={ staticWith : 512,//链接静态图宽度 staticHeight : 320,//链接静态图的高度 container : 'mapcontainer',//显示map的节点id defzoom:12,//默认缩放比例 map : '', marker : '', city : '深圳', infoWinContent : '请移动此标记到您的婚礼地点位置!', /** 提示信息窗内容 */ infoOpts : { width : 100, // 信息窗口宽度 height: 50, // 信息窗口高度 title : "提示:" // 信息窗口标题 }, /** *默认显示窗口 */ defWindow : function(){ this.map = new BMap.Map(this.container); this.map.centerAndZoom(this.city,this.defzoom); // 通过城市名初始化地图 this.map.addEventListener("load", function(){ // 初始化方法执行完成后即可获取地图中心点信息 MapControl.marker = new BMap.Marker( this.getCenter()); // 创建标注 this.addOverlay(MapControl.marker ); // 将标注添地图中 MapControl.marker.enableDragging(); var infoWindow = new BMap.InfoWindow(MapControl.infoWinContent, MapControl.infoOpts); // 创建信息窗口对象 MapControl.marker.addEventListener("mouseover", function(){ this.openInfoWindow(infoWindow); // 打开信息窗口 }) MapControl.marker.addEventListener("mouseout", function(){ this.closeInfoWindow(); // 打开信息窗口 }) }) //map 增操作 this.map.addControl(new BMap.NavigationControl()); this.map.addControl(new BMap.ScaleControl()); this.map.addControl(new BMap.OverviewMapControl()); this.map.addControl(new BMap.MapTypeControl()); }, /** * 搜索地址 */ search : function(address){ if(this.map=='' || this.map == 'undefined' || address=='' ){ return ; } this.city=address; this.defWindow(); }, /** * 获取静态图片地址 */ getStaticMap : function(){ if(this.map=='' || this.map == 'undefined' || this.marker=='' ){ return ; } var center=this.map.getCenter().lng+','+this.map.getCenter().lat; var markers= this.marker.getPosition().lng+','+this.marker.get

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值