js百度地圖滾輪縮放所在點(diǎn)偏移問(wèn)題解決
提出問(wèn)題
<!DOCTYPE html>
<html>
<head>
? ? <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
? ? <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
? ? <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=您的ak"></script>
? ? <!-- 引入樣式 -->
? ? <link rel="stylesheet" rel="external nofollow" >
? ? <style type="text/css">
? ? ? ? [v-cloak] {
? ? ? ? ? ? display: none;
? ? ? ? }
? ? ? ? #allmap {
? ? ? ? ? ? width: 600px;
? ? ? ? ? ? height: 600px;
? ? ? ? ? ? left: 180px;
? ? ? ? ? ? overflow: hidden;
? ? ? ? ? ? margin: 0;
? ? ? ? ? ? font-family: "微軟雅黑";
? ? ? ? }
? ? </style>
? ? <title>地圖展示</title>
</head>
<body>
? ? <div id="container" v-cloak>
? ? ? ? <div>
? ? ? ? ? ? <el-button @click="openMap">Button</el-button>
? ? ? ? </div>
? ? ? ? <div style="margin-top:1000px;">
? ? ? ? ? ? <el-button @click="openMap">Button</el-button>
? ? ? ? </div>
? ? ? ? <el-dialog :visible.sync="visible" title="地圖展示">
? ? ? ? ? ? <div id="allmap"></div>
? ? ? ? </el-dialog>
? ? </div>
</body>
<!-- import Vue before Element -->
<script src="https://unpkg.com/vue/dist/vue.js"></script>
<!-- import JavaScript -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script>
</html>
<script type="text/javascript">
? ? new Vue({
? ? ? ? el: '#container',
? ? ? ? data: function () {
? ? ? ? ? ? return {
? ? ? ? ? ? ? ? visible: false,
? ? ? ? ? ? ? ? map: null
? ? ? ? ? ? }
? ? ? ? },
? ? ? ? mounted: function () {
? ? ? ? },
? ? ? ? methods: {
? ? ? ? ? ? openMap: function () {
? ? ? ? ? ? ? ? this.visible = true;
? ? ? ? ? ? ? ? this.$nextTick(function () {
? ? ? ? ? ? ? ? ? ? const map = new BMap.Map("allmap");
? ? ? ? ? ? ? ? ? ? this.map = map
? ? ? ? ? ? ? ? ? ? //添加地圖類(lèi)型控件
? ? ? ? ? ? ? ? ? ? this.map.addControl(new BMap.MapTypeControl({
? ? ? ? ? ? ? ? ? ? ? ? mapTypes: [
? ? ? ? ? ? ? ? ? ? ? ? ? ? BMAP_NORMAL_MAP,
? ? ? ? ? ? ? ? ? ? ? ? ? ? BMAP_HYBRID_MAP
? ? ? ? ? ? ? ? ? ? ? ? ]
? ? ? ? ? ? ? ? ? ? }));
? ? ? ? ? ? ? ? ? ? this.map.enableScrollWheelZoom(true); ? ? //開(kāi)啟鼠標(biāo)滾輪縮放?
? ? ? ? ? ? ? ? ? ? this.map.centerAndZoom(new BMap.Point(116.404, 39.915), 11); ?// 初始化地圖,設(shè)置中心點(diǎn)坐標(biāo)和地圖級(jí)別
? ? ? ? ? ? ? ? })
? ? ? ? ? ? },
? ? ? ? },
? ? ? ? beforeDestroy: function () {
? ? ? ? ? ? this.map = null
? ? ? ? }
? ? })
</script>分析問(wèn)題
運(yùn)行上述代碼,會(huì)發(fā)現(xiàn)點(diǎn)擊第一個(gè)按鈕,彈窗中的地圖正常顯示,滾輪縮放位置也不會(huì)發(fā)生偏移。但是點(diǎn)擊第二個(gè)按鈕,彈窗中的地圖在滾輪縮放時(shí),放大時(shí)位置是靠上偏移的,縮小時(shí)位置是靠下偏移的。為啥會(huì)出現(xiàn)這種現(xiàn)象,是不是所有在線(xiàn)地圖都有這個(gè)問(wèn)題?幸運(yùn)的是,高德地圖、騰訊地圖不存在此問(wèn)題,百度地圖偏偏有這個(gè)問(wèn)題。
原因在于百度地圖默認(rèn)定位是取瀏覽器文檔對(duì)象的scrollTop=0的位置。如果文檔也就是html頁(yè)面出現(xiàn)滾動(dòng)條,當(dāng)你地圖不是在scrollTop=0的時(shí)候出現(xiàn)時(shí),那么地圖的中心位置其實(shí)是有偏移的,偏移的距離就是滾動(dòng)條滾動(dòng)的距離。這個(gè)時(shí)候縮放就會(huì)出現(xiàn)上述偏移的情況。
解決問(wèn)題
針對(duì)百度地圖的這種特殊設(shè)計(jì),我們只好采取相應(yīng)對(duì)策。
<el-dialog :visible.sync="visible" title="地圖展示" @closed="mapClose" @open="mapOpen">
<div id="allmap"></div>
</el-dialog>
上述代碼添加了開(kāi)啟和關(guān)閉事件處理
我們只要在彈窗打開(kāi)的時(shí)候,檢查滾輪位置是否在最頂部,如果不在的話(huà),調(diào)整到最頂部,然后在彈窗關(guān)閉的時(shí)候,恢復(fù)到最初的位置即可。
貼上我的代碼:
mapOpen: function () {
this.top = this.getScrollTop()
if (this.top) {
this.setScrollTop(0)
}
},
mapClose: function () {
this.setScrollTop(this.top);
this.top = 0;
}
getScrollTop: function () {
let scrollTop = 0;
if (document.documentElement && document.documentElement.scrollTop) {
scrollTop = document.documentElement.scrollTop;
} else if (document.body) {
scrollTop = document.body.scrollTop;
}
return scrollTop;
},
setScrollTop: function (top) {
if (!isNaN(top)) {
if (document.documentElement && document.documentElement.scrollTop !== undefined) {
document.documentElement.scrollTop = top;
} else if (document.body) {
document.body.scrollTop = top;
}
}
}
結(jié)語(yǔ)
到此這篇關(guān)于js百度地圖滾輪縮放所在點(diǎn)偏移問(wèn)題解決的文章就介紹到這了,更多相關(guān)js百度地圖滾輪縮放 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS 獲取HTML標(biāo)簽內(nèi)的子節(jié)點(diǎn)的方法
下面小編就為大家?guī)?lái)一篇JS 獲取HTML標(biāo)簽內(nèi)的子節(jié)點(diǎn)的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09
js字符限制(字符截取) 一個(gè)中文漢字算兩個(gè)字符
有時(shí)候我們需要限制用戶(hù)的輸入或者需要截取一定長(zhǎng)度的字符串都需要用到這樣的功能代碼,這里腳本之家小編就為大家分享一下2017-09-09
JavaScript中的boolean布爾值使用學(xué)習(xí)及相關(guān)技巧講解
JavaScript中的boolean布爾值使用學(xué)習(xí)及相關(guān)技巧講解,特別是Boolean的用法以及適用!!將truthy或falsy值轉(zhuǎn)換為布爾值的用法非常巧妙,需要的朋友可以參考下2016-05-05
高性能JavaScript循環(huán)語(yǔ)句和條件語(yǔ)句
這篇文章主要為大家介紹了高性能JavaScript循環(huán)語(yǔ)句和條件語(yǔ)句,感興趣的小伙伴們可以參考一下2016-01-01
JavaScript實(shí)現(xiàn)背景自動(dòng)切換小案例
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)背景自動(dòng)切換小案例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
JS實(shí)現(xiàn)數(shù)組去重及數(shù)組內(nèi)對(duì)象去重功能示例
這篇文章主要介紹了JS實(shí)現(xiàn)數(shù)組去重及數(shù)組內(nèi)對(duì)象去重功能,結(jié)合實(shí)例形式分析了ES5與ES6兩種版本針對(duì)數(shù)組去重的相關(guān)操作技巧,需要的朋友可以參考下2019-02-02
JS+Canvas實(shí)現(xiàn)的俄羅斯方塊游戲完整實(shí)例
這篇文章主要介紹了JS+Canvas實(shí)現(xiàn)的俄羅斯方塊游戲,結(jié)合完整實(shí)例形式分析了Canvas技術(shù)實(shí)現(xiàn)俄羅斯方塊游戲的步驟、技術(shù)難點(diǎn)與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-12-12

