码迷,mamicode.com
首页 > 其他好文 > 详细

vue中使用高德地图

时间:2019-08-29 20:09:04      阅读:81      评论:0      收藏:0      [点我收藏+]

标签:size   event   result   ons   misc   his   pad   def   use   

1.安装

cnpm install vue-amap --save

2.main.js 中引入

import VueAMap from ‘vue-amap‘
Vue.use(VueAMap)
VueAMap.initAMapApiLoader({
  key: ‘3ebdb3c7a684a4e64f39ddd306056522‘,
  plugin: [‘AMap.Scale‘, ‘AMap.OverView‘, ‘AMap.ToolBar‘, ‘AMap.MapType‘, ‘AMap.PlaceSearch‘, ‘AMap.Geolocation‘, ‘AMap.Geocoder‘],
  v: ‘1.4.4‘,
  uiVersion: ‘1.0‘})
‘‘‘
key: 高德的key(自己申请)

plugin: 引用的插件(根据需要引入)

v: 高德SDK 版本

uiVersion:UI库 版本
‘‘‘

3.在map.vue中引用

<template>
    <div class="container">
        <div class="search-box">
            <input
                    v-model="searchKey"
                    type="search"
                    id="search">
            <button @click="searchByHand">搜索</button>
            <div class="tip-box" id="searchTip"></div>
        </div>
        <!--
          amap-manager: 地图管理对象
          vid:地图容器节点的ID
          zooms: 地图显示的缩放级别范围,在PC上,默认范围[3,18],取值范围[3-18];在移动设备上,默认范围[3-19],取值范围[3-19]
          center: 地图中心点坐标值
          plugin:地图使用的插件
          events: 事件
        -->
        <el-amap class="amap-box"
                 :amap-manager="amapManager"
                 :vid="‘amap-vue‘"
                 :zoom="zoom"
                 :plugin="plugin"
                 :center="center"
                 :events="events"
        >
            <!-- 标记 -->
            <el-amap-marker v-for="(marker, index) in markers" :position="marker" :key="index"></el-amap-marker>
        </el-amap>
    </div>


</template>

<style>

    .container {
        width: 700px;
        height: 500px;
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate3d(-50%, -50%, 0);
        border: 1px solid #999;
    }

    .search-box {
        position: absolute;
        z-index: 5;
        width: 70%;
        left: 13%;
        top: 10px;
        height: 30px;
    }

    .search-box input {
        float: left;
        width: 80%;
        height: 100%;
        border: 1px solid #30ccc1;
        padding: 0 8px;
        outline: none;
    }

    .search-box button {
        float: left;
        width: 20%;
        height: 100%;
        background: #30ccc1;
        border: 1px solid #30ccc1;
        color: #fff;
        outline: none;
    }

    .tip-box {
        width: 100%;
        max-height: 260px;
        position: absolute;
        top: 30px;
        overflow-y: auto;
        background-color: #fff;
    }
</style>

<script>

    import {AMapManager, lazyAMapApiLoaderInstance} from vue-amap

    let amapManager = new AMapManager()
    export default {
        data() {
            let self = this
            return {
                address: null,
                searchKey: ‘‘,
                amapManager,
                markers: [],
                searchOption: {
                    city: 全国,
                    citylimit: true
                },
                center: [121.329402, 31.228667],
                zoom: 17,
                lng: 0,
                lat: 0,
                loaded: false,
                events: {
                    init() {
                        lazyAMapApiLoaderInstance.load().then(() => {
                            self.initSearch()
                        })
                    },
                    // 点击获取地址的数据
                    click(e) {
                        // console.log(e)
                        self.markers = []
                        let {lng, lat} = e.lnglat
                        self.lng = lng
                        self.lat = lat
                        self.center = [lng, lat]
                        self.markers.push([lng, lat])
                        // 这里通过高德 SDK 完成。
                        let geocoder = new AMap.Geocoder({
                            radius: 1000,
                            extensions: all
                        })
                        geocoder.getAddress([lng, lat], function (status, result) {
                            if (status === complete && result.info === OK) {
                                if (result && result.regeocode) {
                                    console.log(result.regeocode.formattedAddress)
                                    self.address = result.regeocode.formattedAddress
                                    self.searchKey = result.regeocode.formattedAddress
                                    self.$nextTick()
                                }
                            }
                        })
                    }
                },
                // 一些工具插件
                plugin: [
                    // {
                    //   pName: ‘Geocoder‘,
                    //   events: {
                    //     init (o) {
                    //       console.log(o.getAddress())
                    //     }
                    //   }
                    // },
                    {
                        // 定位
                        pName: Geolocation,
                        events: {
                            init(o) {
                                // o是高德地图定位插件实例
                                o.getCurrentPosition((status, result) => {
                                    if (result && result.position) {
                                        // 设置经度
                                        self.lng = result.position.lng
                                        // 设置维度
                                        self.lat = result.position.lat
                                        // 设置坐标
                                        self.center = [self.lng, self.lat]
                                        self.markers.push([self.lng, self.lat])
                                        // load
                                        self.loaded = true
                                        // 页面渲染好后
                                        self.$nextTick()
                                    }
                                })
                            }
                        }
                    },
                    {
                        // 工具栏
                        pName: ToolBar,
                        events: {
                            init(instance) {
                                console.log(instance);
                            }
                        }
                    },
                    {
                        // 鹰眼
                        pName: OverView,
                        events: {
                            init(instance) {
                                console.log(instance);
                            }
                        }
                    },
                    {
                        // 地图类型
                        pName: MapType,
                        defaultType: 0,
                        events: {
                            init(instance) {
                                console.log(instance);
                            }
                        }
                    },
                    {
                        // 搜索
                        pName: PlaceSearch,
                        events: {
                            init(instance) {
                                console.log(instance)
                            }
                        }
                    }
                ]
            }
        },
        methods: {
            initSearch() {
                let vm = this
                let map = this.amapManager.getMap()
                AMapUI.loadUI([misc/PoiPicker], function (PoiPicker) {
                    var poiPicker = new PoiPicker({
                        input: search,
                        placeSearchOptions: {
                            map: map,
                            pageSize: 10
                        },
                        suggestContainer: searchTip,
                        searchResultsContainer: searchTip
                    })
                    vm.poiPicker = poiPicker
                    // 监听poi选中信息
                    poiPicker.on(poiPicked, function (poiResult) {
                        // console.log(poiResult)
                        let source = poiResult.source
                        let poi = poiResult.item
                        if (source !== search) {
                            poiPicker.searchByKeyword(poi.name)
                        } else {
                            poiPicker.clearSearchResults()
                            vm.markers = []
                            let lng = poi.location.lng
                            let lat = poi.location.lat
                            let address = poi.cityname + poi.adname + poi.name
                            vm.center = [lng, lat]
                            vm.markers.push([lng, lat])
                            vm.lng = lng
                            vm.lat = lat
                            vm.address = address
                            vm.searchKey = address
                        }
                    })
                })
            },
            searchByHand() {
                if (this.searchKey !== ‘‘) {
                    this.poiPicker.searchByKeyword(this.searchKey)
                }
            }
        }
    }


</script>

4.在.eslintrc.js 中引入 globals

globals: {
        ‘AMap‘: false,
        ‘AMapUI‘: false
    }

 

vue中使用高德地图

标签:size   event   result   ons   misc   his   pad   def   use   

原文地址:https://www.cnblogs.com/zhouze/p/11431553.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!