欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue組件之高德地圖地址選擇功能的實例代碼

 更新時間:2019年06月21日 14:34:32   作者:similar  
這篇文章主要介紹了Vue組件之 高德地圖地址選擇功能的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

注:本文基于上一篇文章【Vue-Cli 3.0 中配置高德地圖 】 ,采用直接引入高德 SDK 的方式來使用高德地圖api

一、效果圖

二、組件要實現(xiàn)的功能

1. 如果有傳入坐標點,則定位到坐標點

2. 如果沒有傳入坐標點,則定位到當前所在位置

3. 定位成功要在右側顯示經(jīng)緯度和地址

4. 可以通過拖動 標記 來調(diào)整定位點

5. 標記 拖動后,右側要顯示拖動后的經(jīng)緯度和地址

6. 點擊確定按鈕,返回最后的坐標點和地名給父組件

三、 組件實現(xiàn)具體代碼

<template>
 <div class="map-box" :style="{ width: width, height: height }">
 <div id="amap" class="amap"></div>
 <div class="detail">
  <p>經(jīng)度:{{point ? point[0] : '-'}}</p>
  <p>緯度:{{point ? point[1] : '-'}}</p>
  <p>地址:{{address}}</p>
  <button size="mini" class="btnmap" @click="commit">確定</button>
 </div>
 </div> 
</template>
<script>
import AMap from 'AMap'
export default {
 props: {
 width: { type: String, default: '100%' },
 height: { type: String, default: '400px' },
 lnglat: {
  type: Array,
  validator: (value) => {
  return value.length === 2
  }
 }
 },
 data () {
 return { address: '', point: this.lnglat }
 },
 mounted () {
 this.init(this.point)
 },
 methods: {

 // 初始化
 init (lnglat) {

  // 地圖實例對象 (amap 為容器的id)
  let amap = new AMap.Map('amap', {
  resizeEnable: true,
  zoom: 15
  })

  // 注入插件(定位插件,地理編碼插件)
  amap.plugin(['AMap.Geolocation', 'AMap.Geocoder'])

  // 定位
  this.currentPosition(amap, lnglat)
 },

 currentPosition (map, lnglat) {
  if (lnglat) {
  // 有傳入坐標點,直接定位到坐標點
  map.setCenter(lnglat)
  this.addMark(map, lnglat)

  // 獲取地址
  this.getAddress(lnglat)
  } else {
  // 沒有傳入坐標點,則定位到當前所在位置
  let geolocation = new AMap.Geolocation({
   enableHighAccuracy: true,
   timeout: 10000,
   zoomToAccuracy: true,  
   buttonPosition: 'RB'
  })
  geolocation.getCurrentPosition((status, result) => {
   if (status === 'complete') {
   let points = [result.position.lng, result.position.lat]
   map.setCenter(points) // 設置中心點
   this.addMark(map, points) // 添加標記

   // 存下坐標與地址
   this.point = points
   this.getAddress(points)
   } else {
   console.log('定位失敗', result)
   }
  })
  }
 },

 // 添加標記
 addMark (map, points) {
  let marker = new AMap.Marker({
  map: map,
  position: points,
  draggable: true, // 允許拖動
  cursor: 'move',
  raiseOnDrag: true
  })
  marker.on('dragend', (e) => {
  let position = marker.getPosition()

  // 存下坐標與地址
  this.point = [position.lng, position.lat]
  this.getAddress([position.lng, position.lat])
  })
 },

 // 根據(jù)坐標返回地址(逆地理編碼)
 getAddress (points) {
  let geocoder = new AMap.Geocoder({ radius: 1000 })
  geocoder.getAddress(points, (status, result) => {
  if (status === 'complete' && result.regeocode) {
   this.address = result.regeocode.formattedAddress
  }
  })
 },

 commit () {
  this.$emit('location', this.point, this.address)
 }
 }
}
</script>

<style lang="scss" scoped>
.map-box {
 box-sizing: border-box;
 background-color: #ddd;
 padding: 15px;
 &:after {
 content: '';
 display: block;
 clear: both;
 }
 .amap, .detail {
 float: left;
 height: 100%;
 }
 .amap {
 width: 75%; 
 }
 .detail {
 width: 25%;
 background-color: #fff;
 padding: 0 15px; 
 border-left: 1px solid #eee;
 box-sizing: border-box;
 word-wrap: break-word;
 }
 .btnmap {
 width: 100%;
 margin: 30px 0 0 0;
 padding: 5px 0;
 color: #fff;
 cursor: pointer;
 background-color: #409eff;
 border: none; 
 border-radius: 3px;
 &:hover {
  background-color: #66b1ff;
 }
 }
}
</style>

四、調(diào)用組件

<template>
 <div class="box">
 <xmap width="700px" height="500px" :lnglat="[114.433703, 30.446243]" @location="location"></xmap>
 </div>
</template>
<script>
import xmap from '@/components/map'
export default {
 components: { xmap }, 
 methods: {
 location(point, address) {
  alert(`坐標:${point[0]},${point[1]} - 地址:${address}`)
 }
 }
}
</script>

總結

以上所述是小編給大家介紹的Vue組件之高德地圖地址選擇功能的實例代碼,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

相關文章

  • 詳解Vue使用 vue-cli 搭建項目

    詳解Vue使用 vue-cli 搭建項目

    本篇文章主要介紹了詳解Vue使用 vue-cli 搭建項目,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • Vue模仿實現(xiàn)京東商品大圖放大鏡效果

    Vue模仿實現(xiàn)京東商品大圖放大鏡效果

    這篇文章主要為大家介紹了Vue實現(xiàn)京東網(wǎng)站商品放大鏡效果示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • Vue登錄功能實現(xiàn)

    Vue登錄功能實現(xiàn)

    本文主要介紹了 Vue 登錄功能實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • vue/cli?配置動態(tài)代理無需重啟服務的操作方法

    vue/cli?配置動態(tài)代理無需重啟服務的操作方法

    vue-cli是vue.js的腳手架,用于自動生成vue.js+webpack的項目模板,分為vue?init?webpack-simple?項目名和vue?init?webpack?項目名兩種,這篇文章主要介紹了vue/cli?配置動態(tài)代理,無需重啟服務,需要的朋友可以參考下
    2022-05-05
  • vue.js全局API之nextTick全面解析

    vue.js全局API之nextTick全面解析

    本篇文章主要介紹了vue.js全局API之nextTick全面解析,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • 在Vue中使用echarts的實例代碼(3種圖)

    在Vue中使用echarts的實例代碼(3種圖)

    本篇文章主要介紹了在Vue中使用echarts的實例代碼(3種圖),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • vue.js中導出Excel表格的案例分析

    vue.js中導出Excel表格的案例分析

    這篇文章主要介紹了vue.js中如何導出Excel表格,在項目中經(jīng)常會遇到這樣的需求,今天小編分步驟通過實例代碼給大家詳細介紹,需要的朋友可以參考下
    2019-06-06
  • 關于Element-UI可編輯表格的實現(xiàn)過程

    關于Element-UI可編輯表格的實現(xiàn)過程

    這篇文章主要介紹了關于Element-UI可編輯表格的實現(xiàn)過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Vue.js實現(xiàn)簡單動態(tài)數(shù)據(jù)處理

    Vue.js實現(xiàn)簡單動態(tài)數(shù)據(jù)處理

    本篇文章主要介紹了Vue.js實現(xiàn)簡單動態(tài)數(shù)據(jù)處理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • vue項目出現(xiàn)頁面空白的解決方案

    vue項目出現(xiàn)頁面空白的解決方案

    今天小編就為大家分享一篇vue項目出現(xiàn)頁面空白的解決方案,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10

最新評論