返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue-amap安装和用法步骤
  • 859
分享到

vue-amap安装和用法步骤

2024-04-02 19:04:59 859人浏览 独家记忆
摘要

之前分享了异步加载高德地图api的用法,现在记录一下Vue-amap的用法。 vue-amap是饿了么开源的一套基于 Vue 2.0 和高德地图的地图组件。 数据状态与地图状态单向绑

之前分享了异步加载高德地图api的用法,现在记录一下Vue-amap的用法。

vue-amap是饿了么开源的一套基于 Vue 2.0 和高德地图的地图组件。 数据状态与地图状态单向绑定,开发者无需关心地图的具体操作。

官方文档:https://elemefe.GitHub.io/vue-amap/

步骤如下:

1.npm 安装

npm install vue-amap --save

如果是CDN方式,目前可通过unpkg.com/vue-amap获取最新版本的资源。

<script src="Https://unpkg.com/vue-amap/dist/index.js"></script>

2.使用实例

实例需求描述:搜索并选择地址,选中后地图定位到该地址,并获取经纬度自动填入下方的输入框中。

注:实例中使用的框架是ElementUI,其表单组件使用比较方便。

实现步骤:

(1)安装后在main.js中设置以下内容:


import VueAMap from "vue-amap";
Vue.use(VueAMap);
// 初始化vue-amap
VueAMap.initAMapApiLoader({
  key: "your key", // 这里写你申请的高德地图的key
  plugin: ["AMap.Autocomplete", "AMap.Geocoder", "AMap.Geolocation"],
  v: "1.4.15",
  uiVersion: "1.1"
});

(2)定义地图搜索组件 base/mapSearch/baseMapSearch.vue


<template>
  <div>
    <div class="search-box">
      <el-input
        v-model="searchKey"
        type="search"
        id="search"
        placeholder="请输入详细地址"
      ></el-input>
      <!--<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: 事件
    -->
    <div class="amap-box">
      <el-amap
        :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>
  </div>
</template>
<script>
import { AMapManager, lazyAMapApiLoaderInstance } from "vue-amap";
let amapManager = new AMapManager();
export default {
  props: ["city", "value", "longitude", "latitude", "isEdit"],
  data() {
    let self = this;
    return {
      address: null,
      searchKey: "",
      amapManager,
      markers: [],
      searchOption: {
        city: this.city ? this.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) {
          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) {
                self.address = result.regeocode.fORMattedAddress;
                self.searchKey = result.regeocode.formattedAddress;
                self.$emit("updateLocation", lng, lat, self.searchKey);
                self.$nextTick();
              }
            }
          });
        }
      },
      // 一些工具插件
      plugin: [
        {
          // 定位
          pName: "Geolocation",
          events: {
            init(o) {
              // o是高德地图定位插件实例
              o.getCurrentPosition((status, result) => {
                if (result && result.position) {
                  if (self.isEdit) {
                    // 设置经度
                    self.lng = self.longitude;
                    // 设置维度
                    self.lat = self.latitude;
                    // 设置坐标
                    self.center = [self.longitude, self.latitude];
                    self.markers.push([self.longitude, self.latitude]);
                  } else {
                    // 设置经度
                    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();
                }
              });
            }
          }
        }
      ]
    };
  },
  created() {
    if (this.value) {
      this.searchKey = this.value;
      this.address = this.value;
    }
    if (this.longitude && this.latitude) {
      this.lng = this.longitude;
      this.lat = this.latitude;
      this.center = [this.longitude, this.latitude];
      this.markers.push([this.longitude, this.latitude]);
    }
  },
  methods: {
    // 选择地址后自动定位到当前地址附近
    updateAddress(value, longitude, latitude) {
      this.searchKey = value;
      this.address = value;
      this.lng = longitude;
      this.lat = latitude;
      this.center = [longitude, latitude];
      this.markers.push([longitude, latitude]);
    },
    initSearch() {
      let vm = this;
      let map = this.amapManager.getMap();
      AMapUI.loadUI(["misc/PoiPicker"], function(PoiPicker) {
        let poiPicker = new PoiPicker({
          input: "search",
          placeSearchOptions: {
            map: map,
            pageSize: 10
          },
          suggestContainer: "searchTip",
          searchResultsContainer: "searchTip"
        });
        vm.poiPicker = poiPicker;
        // 监听poi选中信息
        poiPicker.on("poiPicked", function(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.name; // 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;
            vm.$emit("updateLocation", lng, lat, vm.searchKey);
          }
        });
      });
    },
    searchByHand() {
      if (this.searchKey !== "" && this.poiPicker) {
        this.poiPicker.searchByKeyword(this.searchKey);
      }
    }
  }
};
</script>
<style lang="stylus">
.search-box {
  margin-top: 6px;
  width: 100%;
}
.search-box input {
  padding: 0 15px;
  width: 100%;
  height: 32px;
  line-height: 32px;
  color: #606266;
  border: 1px solid #dcdfe6;
  border-radius: 4px;
}
.search-box input:focus {
  border-color: #409eff;
  outline: 0;
}
.search-box input::-WEBkit-input-placeholder {
  color: #c0c4cc;
}
.tip-box {
  width: 100%;
  max-height:280px;
  position: absolute;
  top: 72px;
  z-index: 10000;
  overflow-y: auto;
  background-color: #fff;
}
</style>
<style>
.amap-ui-poi-picker-sugg,
.amap_lib_placeSearch {
  border: 1px solid #eee;
  border-radius: 4px;
}
.amap-box {
  height: 200px;
}
</style>

这里样式使用了stylus,可自行转换其他样式。

(3)在组件中使用地图搜索组件,这里以弹窗为例


<template>
  <el-dialog
    :title="title"
    :visible.sync="visible"
    :before-close="handleClose"
    width="600px"
    append-to-body
    :close-on-click-modal="false"
    :close-on-press-escape="false"
  >
    <div class="form-info">
      <el-form
        :model="form"
        ref="form"
        :rules="rules"
        size="small"
        label-width="110px"
      >
        <el-form-item label="选择地址" prop="address">
          <base-map-search
            ref="mapSearch"
            :city="form.city"
            :value="form.address"
            :longitude="form.addLon"
            :latitude="form.addLat"
            :isEdit="isEdit"
            @updateLocation="updateLocation"
          />
        </el-form-item>
        <el-row>
          <el-col :span="12">
            <el-form-item prop="addLon" label="经度">
              <el-input
                v-model.number="form.addLon"
                :maxlength="15"
                placeholder="请输入经度"
              ></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12" class="right-label-form-item">
            <el-form-item prop="addLat" label="纬度">
              <el-input
                v-model.number="form.addLat"
                :maxlength="15"
                placeholder="请输入纬度"
              ></el-input>
            </el-form-item>
          </el-col>
        </el-row>
      </el-form>
    </div>
  </el-dialog>
</template>
<script>
import BaseMapSearch from "../base/mapSearch/baseMapSearch";
export default {
    props: ["visible", "isEdit", "detail"],
    components: {
      BaseMapSearch
    },
    data() {
        return {
            title: "添加地址",
            form: {
                address: "",
                addLon: "",
                addLat: ""
            },
            rules: {
                address: [
                  {
                    required: true,
                    message: "请输入地址",
                    trigger: ["blur", "change"]
                  }
                ],
                addLat: [
                  {
                    required: true,
                    message: "请输入纬度",
                    trigger: ["blur", "change"]
                  }
                ],
                addLon: [
                  {
                    required: true,
                    message: "请输入经度",
                    trigger: ["blur", "change"]
                  }
                ],
            }
        };
    },
    created() {
      if (this.isEdit) {
        this.initForm();
      }
    },
    methods: {
        // 初始化表单
        initForm() {
          this.title = "修改地址";
          if (this.detail) {
            this.form = { ...this.detail };
          }
        },
        // 地图搜索选址
        updateLocation(lng, lat, address) {
          this.form.addLon = lng;
          this.form.addLat = lat;
          this.form.address = address;
        },
        handleClose() {
          this.$emit("update:visible", false);
        }
    }
};
</script>

(4)这时,如果项目中使用了ESlint,会报AMap、AMapUI未定义的错误,我们需要在.eslintrc.js文件中定义globals属性:


module.exports = {
    // ...
    globals: {
      AMap: false,
      AMapUI: false
    }
};

这样就写好了,效果如图:

到此这篇关于vue-amap安装和使用的文章就介绍到这了,更多相关vue-amap安装和使用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: vue-amap安装和用法步骤

本文链接: https://lsjlt.com/news/160688.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • vue-amap安装和用法步骤
    之前分享了异步加载高德地图api的用法,现在记录一下vue-amap的用法。 vue-amap是饿了么开源的一套基于 Vue 2.0 和高德地图的地图组件。 数据状态与地图状态单向绑...
    99+
    2024-04-02
  • vue-amap安装和使用方法是什么
    本篇内容主要讲解“vue-amap安装和使用方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue-amap安装和使用方法是什么”吧!vue-amap是饿了么开源的一套基于 Vue 2....
    99+
    2023-06-22
  • Ubuntu下samba的安装步骤和用法
    这篇文章主要介绍“Ubuntu下samba的安装步骤和用法”,在日常操作中,相信很多人在Ubuntu下samba的安装步骤和用法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Ubuntu下samba的安装步骤...
    99+
    2023-06-16
  • Redis的安装和使用步骤
    本篇内容主要讲解“Redis的安装和使用步骤”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Redis的安装和使用步骤”吧!#下载redishadoop@dbla...
    99+
    2024-04-02
  • Anaconda安装pytorch和paddle的方法步骤
    目录NVIDIA驱动安装与更新Anaconda 的安装Pytorch环境安装NVIDIA驱动安装与更新 首先查看电脑的显卡版本,步骤为:此电脑右击–>管理&ndas...
    99+
    2024-04-02
  • Docker Compose的安装和使用步骤
    目录一、Docker Compose是什么?二、Docker Compose安装步骤三、Docker Compose版本差别四、Docker Compose基本命令一、Docker ...
    99+
    2024-04-02
  • Vue项目安装less和less-loader的详细步骤
    目录第一步:查看webpack和webpack-cli是否安装第二步:确定webpack版本第三步:安装less和less-loader第四步:使用less总结第一步:查看webpa...
    99+
    2022-12-22
    Vue安装less和less-loader Vue安装less Vue安装less-loader
  • Nacos下载和安装步骤
    1. 下载安装包 1. Nacos官网 :https://nacos.io/zh-cn/hub 打开官网,点击前往Github Nacos官网 打开Nacos Github主页,点击Release,点击tags,可以看到所有的版...
    99+
    2023-10-23
    java 微服务 spring boot
  • nvm安装步骤及使用方法
    目录一、nvm说明二、nvm下载三、nvm安装一、nvm说明 nvm 主要是用来管理 nodejs 和 npm 版本的工具,可以用来切换不同版本的 nodejs。 nvm安装使用及常...
    99+
    2023-01-17
    nvm安装使用 nvm安装步骤
  • MHA的安装和部署步骤
    本篇内容介绍了“MHA的安装和部署步骤”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!###########...
    99+
    2024-04-02
  • python和pycharm下载安装步骤
    (此处以python3.7和pcharm2020.2.5为例) 一、python的下载和安装 1、下载 1)首先在浏览器上找到python的官网,点击进入 快捷链接:Python中文网 官网 (p2hp.com) 2)点击页面中的下载 3...
    99+
    2023-09-07
    python pycharm 开发语言
  • mariadb 安装步骤
    下载地址:https://downloads.mariadb.org/mariadb/10.2.10/ ...
    99+
    2024-04-02
  • LDAP安装步骤
    LDAP(Lightweight Directory Access Protocol)是一种用于访问和维护分布式目录信息服务的协议。...
    99+
    2023-09-20
    LDAP
  • ESXI安装步骤
    第一步:通过带外登入界面进入命令行;登入界面后,通过远程控制,进入命令行 第二步:上传esx...
    99+
    2023-09-03
    linux 运维 服务器 Powered by 金山文档
  • mysql8.0安装步骤
    打开下载的MySQL 8.0软件安装包,鼠标右击压缩包 选择【解压到当前文件夹】。 打开解压的【Mysql8.0】文件夹 鼠标右击【mysql-installer-community-8.0.17.0】安装程序,选择【以管理员身份运行...
    99+
    2023-09-14
    mysql 数据库
  • 安装Ruby和安装Rails详细步骤详解
    rbenv安装Ruby rbenv可以管理多个版本的ruby。可以分为3种范围(或者说不同生效作用域)的版本: local版:本地,针对各项目范围(只在某个目录下有效)global版...
    99+
    2024-04-02
  • Python3安装Scrapy的方法步骤
    本文介绍了Python3安装Scrapy的方法步骤,分享给大家,具体如下: 运行平台:Windows Python版本:Python3.x IDE:Sublime text3 一、Scrap...
    99+
    2022-06-04
    步骤 方法 Scrapy
  • linux安装git的方法步骤
    1、简介 Git是一款免费、开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Git是一个开源的分布式版本控制系统,用以有效、高速的处理从很小到非常大的项目版本管理。 Git 是 Linus Torv...
    99+
    2022-06-04
    linux安装git
  • linux安装xmind的方法步骤
    1.下载xmind 百度,官网下载xmind linux版本 或本地下载地址https://www.jb51.nezHnwmt/softs/587908.html 2.解压到安zHnwm装目录 我的安装目录是/opt...
    99+
    2022-06-04
    linux安装xmind
  • Windows10安装Apache2.4的方法步骤
    目录下载Apache Http Sever 2.4添加环境变量配置Apache的路径和监听端口启动Apache Http Server方式一:通过命令行启动方式二:利用Windows启动方式三:利用Apache...
    99+
    2022-06-24
    Windows10安装Apache2.4 安装Apache
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作