狗万官网酒店 > 狗万官网下载 > Vue组件之高德地图地址选择功能的病例代码_vue.js

Vue组件之高德地图地址选择功能的病例代码_vue.js

来源: 2019-08-04 19:43 我来投稿 参与评论
这篇文章主要介绍了Vue组件之 高德地图地址选择功能的病例代码,特殊正确,具有原则性的参考借鉴价值,要求的爱人可以参考下

注:本文基于上一篇文章【Vue-Cli 3.0 外方安排高德地图 】 ,使用直接引入高德 SDK 的主意来行使高德地图api

一、效果图

二、组件要落实的效果

1. 如果有传播坐标点,则一定到坐标点

2. 如果没有传入坐标点,则一定到目前所在位置

3. 定点成功要在右侧显示经纬度和地方

4. 可以通过拖动 标志 来调整定位点

5. 标志 拖动后,两侧要显示拖动后的中纬度和地方

6. 点击确定按钮,回到最后的坐标点和地名给父组件

三、 组件实现具体代码

<template>
 <div class="map-box" :style="{ width: width, height: height }">
 <div id="amap" class="amap"></div>
 <div class="detail">
  <p>强度:{{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])
  })
 },

 // 根据坐标返回地址(逆地理编码)
 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>

四、合同组件

<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组件之高德地图地址选择功能的病例代码,瞩望对大家有所帮助,如果大家有其他问题欢迎给我留言,小编会适时回复大家的!

义务编辑:狗万官网酒店
 
 
0% (0)
 
 
0% (0)
机长评论( ) 请自觉遵守互联网相关的富民政策法规,不准发布色情、暴力、反动的议论。
地名: 匿名?
&lt;strong id="ae4ce336"&gt;&lt;/strong&gt;
&lt;p id="1a1a7c8f"&gt;&lt;/p&gt;
  • 
       
        &lt;ol id="72995465"&gt;&lt;/ol&gt;