国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

vue項目使用高德地圖的定位及關鍵字搜索功能的實例代碼(踩坑經驗)

瀏覽:105日期:2022-06-12 11:40:54

1.首先在index.html引入高德地圖的秘鑰。如圖:

vue項目使用高德地圖的定位及關鍵字搜索功能的實例代碼(踩坑經驗)

注意:如果使用關鍵字搜索功能要加上 plugin=AMap.Autocomplete,AMap.PlaceSearch,否則功能無法使用,并會報錯2. 定位功能,代碼如下:

const map = new AMap.Map(this.$refs.container, { resizeEnable: true }) // 創(chuàng)建Map實例 const options = { ’showButton’: true, // 是否顯示定位按鈕 ’buttonPosition’: ’LB’, // 定位按鈕的位置 ’buttonOffset’: new AMap.Pixel(10, 20), // 定位按鈕距離對應角落的距離 ’showMarker’: true, // 是否顯示定位點 ’showCircle’: true, // 是否顯示定位精度圈 ’circleOptions’: {// 定位精度圈的樣式 ’strokeColor’: ’#0093FF’, ’noSelect’: true, ’strokeOpacity’: 0.5, ’strokeWeight’: 1, ’fillColor’: ’#02B0FF’, ’fillOpacity’: 0.25 }, zoomToAccuracy: true // 定位成功后是否自動調整地圖視野到定位點 } AMap.plugin([’AMap.Geolocation’], function() { const geolocation = new AMap.Geolocation(options) map.addControl(geolocation) geolocation.getCurrentPosition() }) //下面是點擊地圖時加入mark。注意:要在綁定事件前記錄this,否則在綁定的回調方法中使用this將是該事件的this const _this = this AMap.event.addListener(map, ’click’, function(e) { map.clearMap() // 清除地圖上所有添加的覆蓋物 new AMap.Marker({ position: e.lnglat, map: map }) _this.handleMap(e.lnglat.getLng(), e.lnglat.getLat()) })

3.關鍵字搜索功能html部分代碼(注意ref,id,class的名字要和官網保持一致,否則可能出不來想要的效果):

<template> <div class='map-chart'> <div ref='container' /> <div id='myPageTop'> <table> <tr> <td> <label>請輸入關鍵字:</label> </td> </tr> <tr> <td> <input id='tipinput'> </td> </tr> </table> </div> </div></template>

script代碼:

export default { name: ’Map’, props: [], data() { return { placeSearch: null } }, mounted() { this.mapInit() }, methods: { mapInit() { const map = new AMap.Map(this.$refs.container, { resizeEnable: true }) // 創(chuàng)建Map實例 const options = { ’showButton’: true, // 是否顯示定位按鈕 ’buttonPosition’: ’LB’, // 定位按鈕的位置 ’buttonOffset’: new AMap.Pixel(10, 20), // 定位按鈕距離對應角落的距離 ’showMarker’: true, // 是否顯示定位點 ’showCircle’: true, // 是否顯示定位精度圈 ’circleOptions’: {// 定位精度圈的樣式 ’strokeColor’: ’#0093FF’, ’noSelect’: true, ’strokeOpacity’: 0.5, ’strokeWeight’: 1, ’fillColor’: ’#02B0FF’, ’fillOpacity’: 0.25 }, zoomToAccuracy: true // 定位成功后是否自動調整地圖視野到定位點 } //注意:要在綁定事件前記錄this,否則在綁定的回調方法中使用this將是該事件的this const _this = this // 輸入提示 const autoOptions = { input: ’tipinput’ } const auto = new AMap.Autocomplete(autoOptions) this.placeSearch = new AMap.PlaceSearch({ map: map }) // 構造地點查詢類 AMap.event.addListener(auto, ’select’, this.select)// 注冊監(jiān)聽,當選中某條記錄時會觸發(fā) //點擊搜索出的mark點事件 AMap.event.addListener(this.placeSearch, ’markerClick’, function(e) { _this.$emit(’bMapDate’, e.data.location.lng, e.data.location.lat) }) }, select(e) { this.placeSearch.setCity(e.poi.adcode) this.placeSearch.search(e.poi.name) // 關鍵字查詢查詢 }, handleMap(o, a) { this.$emit(’bMapDate’, o, a) } }}</script>

整體完成代碼:

<template> <div class='map-chart'> <div ref='container' /> <div id='myPageTop'> <table> <tr> <td> <label>請輸入關鍵字:</label> </td> </tr> <tr> <td> <input id='tipinput'> </td> </tr> </table> </div> </div></template><script>export default { name: ’Map’, props: [], data() { return { placeSearch: null } }, mounted() { this.mapInit() }, methods: { mapInit() { const map = new AMap.Map(this.$refs.container, { resizeEnable: true }) // 創(chuàng)建Map實例 const options = { ’showButton’: true, // 是否顯示定位按鈕 ’buttonPosition’: ’LB’, // 定位按鈕的位置 ’buttonOffset’: new AMap.Pixel(10, 20), // 定位按鈕距離對應角落的距離 ’showMarker’: true, // 是否顯示定位點 ’showCircle’: true, // 是否顯示定位精度圈 ’circleOptions’: {// 定位精度圈的樣式 ’strokeColor’: ’#0093FF’, ’noSelect’: true, ’strokeOpacity’: 0.5, ’strokeWeight’: 1, ’fillColor’: ’#02B0FF’, ’fillOpacity’: 0.25 }, zoomToAccuracy: true // 定位成功后是否自動調整地圖視野到定位點 } AMap.plugin([’AMap.Geolocation’], function() { const geolocation = new AMap.Geolocation(options) map.addControl(geolocation) geolocation.getCurrentPosition() }) const _this = this AMap.event.addListener(map, ’click’, function(e) { map.clearMap() // 清除地圖上所有添加的覆蓋物 new AMap.Marker({ position: e.lnglat, map: map }) _this.handleMap(e.lnglat.getLng(), e.lnglat.getLat()) }) // 輸入提示 const autoOptions = { input: ’tipinput’ } const auto = new AMap.Autocomplete(autoOptions) this.placeSearch = new AMap.PlaceSearch({ map: map }) // 構造地點查詢類 AMap.event.addListener(auto, ’select’, this.select)// 注冊監(jiān)聽,當選中某條記錄時會觸發(fā) AMap.event.addListener(this.placeSearch, ’markerClick’, function(e) { _this.$emit(’bMapDate’, e.data.location.lng, e.data.location.lat) }) }, select(e) { this.placeSearch.setCity(e.poi.adcode) this.placeSearch.search(e.poi.name) // 關鍵字查詢查詢 }, handleMap(o, a) { this.$emit(’bMapDate’, o, a) } }}</script><style scoped> .map-chart{ position: relative; margin-bottom:15px; width: 100%; height: 400px; border: 1px #dddddd solid; } /deep/ .amap-logo,/deep/ .amap-copyright { display: none!important; } #container { margin-bottom:15px; width: 100%; height: 400px; border: 1px #dddddd solid; z-index: 99999999; } .button-group { position: absolute; bottom: 20px; right: 20px; font-size: 12px; padding: 10px; } .button-group .button { height: 28px; line-height: 28px; background-color: #0D9BF2; color: #FFF; border: 0; outline: none; padding-left: 5px; padding-right: 5px; border-radius: 3px; margin-bottom: 4px; cursor: pointer; } .button-group .inputtext { height: 26px; line-height: 26px; border: 1px; outline: none; padding-left: 5px; padding-right: 5px; border-radius: 3px; margin-bottom: 4px; cursor: pointer; } #tip { background-color: #fff; padding-left: 10px; padding-right: 10px; position: absolute; font-size: 12px; right: 10px; top: 20px; border-radius: 3px; border: 1px solid #ccc; line-height: 30px; } .amap-info-content { font-size: 12px; } #myPageTop { position: absolute; top: 5px; right: 10px; background: #fff none repeat scroll 0 0; border: 1px solid #ccc; margin: 10px auto; padding:6px; font-family: 'Microsoft Yahei', '微軟雅黑', 'Pinghei'; font-size: 14px; z-index: 99999999; } #myPageTop label { margin: 0 20px 0 0; color: #666666; font-weight: normal; } #myPageTop input { width: 170px; } #myPageTop .column2{ padding-left: 25px; }</style>

由于我在項目中使用了dialog,搜索出來的結果會在蒙版后面顯示,去掉scope和加/deep/、>>>都沒用,最后在index.html加樣式。代碼如下:

<style type='text/css'> .amap-sug-result { z-index: 2999!important; } </style>

效果:

vue項目使用高德地圖的定位及關鍵字搜索功能的實例代碼(踩坑經驗)

以上就是踩了無數坑總結出來的經驗。。。

到此這篇關于vue項目使用高德地圖的定位及關鍵字搜索功能的實例代碼(踩坑經驗)的文章就介紹到這了,更多相關vue 高德地圖定位搜索內容請搜索好吧啦網以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: 高德 地圖
相關文章:
主站蜘蛛池模板: 精品成人网 | 久久草在线看 | 成人a视频片在线观看免费 成人a视频在线观看 | avtt加勒比手机版天堂网 | 黑人一级片 | 一级一片免费看 | 欧美成人h精品网站 | 一区二区三区成人 | 韩国一级黄色大片 | 国产精品久久久久久久久久久搜索 | 国产合集91合集久久日 | 大伊香蕉精品视频在线 | 成人免费视频网站 | 久久综合中文字幕一区二区三区 | 国产成人久视频免费 | 美女黄视频网站 | 美女视频一区二区三区 | 99久久精品毛片免费播放 | 男人操女人逼逼视频 | 一区二区在线播放福利视频 | 九九九九九九 | 欧美成人黄色网 | 羞羞一区二区三区四区片 | 北条麻妃在线一区二区 | 精品一精品国产一级毛片 | 毛片免费的 | 国产成人精品高清免费 | 久久草在线观看 | 国产亚洲欧美日韩国产片 | 国产jk福利视频在线观看 | 国产精品成人在线 | 亚洲高清无在码在线无弹窗 | 欧美a级在线观看 | 亚洲国产高清人在线 | 寡妇一级a毛片免费播放 | 亚洲国产高清在线精品一区 | 99精品在免费线视频 | 亚洲精品久久九九精品 | 夜夜躁狠狠躁日日躁2021 | 99视频在线观看免费 | 久久久黄色大片 |