参考:https://blog.csdn.net/u012724595/article/details/82703579
<!-- gps弹窗 --> <el-dialog v-dialogDrag width="500px" title="Gps位置" :visible.sync="dialogFormGps"> <template> <baidu-map class="bm-view" :center="center" :zoom="zoom" :scroll-wheel-zoom="true" ak="填自己申请的ak" ref="myMap" @ready="mapReady" @click="getClickInfo"> <bm-scale></bm-scale> </baidu-map> </template> <div slot="footer" class="dialog-footer"> <el-button type="primary" @click="dialogFormGps = false">关 闭</el-button> <!-- <el-button type="primary" @click="addData('pojoForm')">确 定</el-button> --> </div> </el-dialog>
import {
BaiduMap,
BmScale,
BmNavigation,
BmOverviewMap,
BmCityList,
BmMarker,
BmControl,
BmView,
BmAutoComplete,
BmLocalSearch
} from "vue-baidu-map";
方法:
// 百度地图方法 // 当选择项发生变化时会触发该事件 handleSelectionChange(val) { var i = 0, valLen = val.length; if (valLen == 0) { this.locData.ids = 0; } else { for (i; i < valLen; i++) { if (i == 0) { this.locData.ids = val[i].id; } else if (i > 0) { this.locData.ids += "," + val[i].id; } } } }, // 当某一行被点击时会触发该事件 参数:row, event, column getRowData(editEqu, event, column) { this.$refs.equTable.toggleRowSelection(editEqu); }, // 设置定位弹出框 setLoc(formName) { if (this.locData.ids == 0) { this.$message({ message: '请选中装备后再设置定位', type: 'warning' }); } else { this.locDialog = true; map.clearOverlays(); } }, // 百度地图 mapReady ({BMap, map}) { this.center.lng = 116.404; this.center.lat = 39.915; this.zoom = 15; window.map = map; //将map变量存储在全局 }, // 地图点击事件 getClickInfo (e) { map.clearOverlays(); var myMarker = new BMap.Marker(new BMap.Point(e.point.lng, e.point.lat)); map.addOverlay(myMarker); this.locData.longitude = e.point.lng; this.locData.latitude = e.point.lat; }, // 设置定位确认 locSubmit(formName) { if (this.locData.longitude == "") { addOper.$message({ message: '请单击地图设置定位后再提交', type: 'warning' }); } else { // 向后台提交locData数据 } this.locDialog = false; }, // 设置定位取消 locCancle(formName) { map.clearOverlays(); this.locDialog = false; } }