位置: IT常识 - 正文

在vue3项目中使用新版高德地图(vue3项目中使用el-dialog)

编辑:rootadmin
在vue3项目中使用新版高德地图

推荐整理分享在vue3项目中使用新版高德地图(vue3项目中使用el-dialog),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue3项目中使用el-dialog,vue项目使用rem,vue3项目中使用vue2组件,vue3项目中使用高德地图,在vue3项目中使用vue2,vue3项目中使用代码编辑工具,在vue3项目中使用vue2,vue3项目中使用el-dialog,内容如对您有帮助,希望把文章链接给更多的朋友!

高德开发平台 : 高德开放平台 | 高德地图API (amap.com)

1. 首先你要注册好账号登录

2. 获取key和密钥 

在vue3项目中使用新版高德地图(vue3项目中使用el-dialog)

 

自2021年12月02日升级,升级之后所申请的 key 必须配备安全密钥 jscode 一起使用

NPM方式安装和使用(基础版):        按 NPM 方式安装使用 Loader :npm i @amap/amap-jsapi-loader --save        在页面中通过NPM 方式安装的使用 :<template> <div class="app-container"> <div style="background-color: #ffffff;"> <div id="container"></div> </div> </div></template><script setup>import AMapLoader from '@amap/amap-jsapi-loader';/*在Vue3中使用时,需要引入Vue3中的shallowRef方法(使用shallowRef进行非深度监听,因为在Vue3中所使用的Proxy拦截操作会改变JSAPI原生对象,所以此处需要区别Vue2使用方式对地图对象进行非深度监听,否则会出现问题,建议JSAPI相关对象采用非响应式的普通对象来存储)*/import { shallowRef } from '@vue/reactivity';import {ref} from "vue";// const map = shallowRef(null);const path = ref([]);const current_position = ref([]);function initMap() { window._AMapSecurityConfig = { securityJsCode: '8e920f73eb2e6880a92ea6662eefc476', } AMapLoader.load({ key:"e4e3d44a98350790a1493450032bbec5", // 申请好的Web端开发者Key,首次调用 load 时必填 version:"2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15 plugins:[''], // 需要使用的的插件列表,如比例尺'AMap.Scale'等 }).then((AMap)=>{ const map = new AMap.Map("container",{ //设置地图容器id viewMode:"3D", //是否为3D地图模式 zoom:13, //初始化地图级别 center:[113.808299,34.791787], //初始化地图中心点位置 }); }).catch(e=>{ console.log(e); })} initMap()</script><style>#container{ padding:0px; margin: 0px; width: 100%; height: 800px;}</style>完整代码:<template> <div class="app-container"> <div style="background-color: #ffffff;"> <div id="container"></div> </div> </div></template><script setup>import AMapLoader from '@amap/amap-jsapi-loader';/*在Vue3中使用时,需要引入Vue3中的shallowRef方法(使用shallowRef进行非深度监听,因为在Vue3中所使用的Proxy拦截操作会改变JSAPI原生对象,所以此处需要区别Vue2使用方式对地图对象进行非深度监听,否则会出现问题,建议JSAPI相关对象采用非响应式的普通对象来存储)*/import { shallowRef } from '@vue/reactivity';import {ref} from "vue";// const map = shallowRef(null);const path = ref([]);const current_position = ref([]);function initMap() { window._AMapSecurityConfig = { securityJsCode: '8e920f73eb2e6880a92ea6662eefc476', } AMapLoader.load({ key:"e4e3d44a98350790a1493450032bbec5", // 申请好的Web端开发者Key,首次调用 load 时必填 version:"2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15 // plugins:[''], // 需要使用的的插件列表,如比例尺'AMap.Scale'等 }).then((AMap)=>{ const map = new AMap.Map("container",{ //设置地图容器id viewMode:"3D", //是否为3D地图模式 zoom:13, //初始化地图级别 center:[113.808299,34.791787], //初始化地图中心点位置 }); // 添加插件 AMap.plugin(["AMap.ToolBar", "AMap.Scale", "AMap.HawkEye","AMap.Geolocation","AMap.MapType","AMap.MouseTool"], function () { //异步同时加载多个插件 // 添加地图插件 map.addControl(new AMap.ToolBar()); // 工具条控件;范围选择控件 map.addControl(new AMap.Scale()); // 显示当前地图中心的比例尺 map.addControl(new AMap.HawkEye()); // 显示缩略图 map.addControl(new AMap.Geolocation()); // 定位当前位置 map.addControl(new AMap.MapType()); // 实现默认图层与卫星图,实时交通图层之间切换 // 以下是鼠标工具插件 const mouseTool = new AMap.MouseTool(map); // mouseTool.rule();// 用户手动绘制折线图,测量距离 mouseTool.measureArea(); // 测量面积 }); // 单击 map.on('click',(e) => { // lng ==> 经度值 lat => 维度值 current_position.value = [e.lnglat.lng,e.lnglat.lat]; path.value.push([e.lnglat.lng,e.lnglat.lat]); // addMarker(); // addPolyLine(); }) // 实例化点标记 // 第一种(封成函数来触发) function addMarker() { const marker = new AMap.Marker({ icon: "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png", position: current_position.value, // 这里我们通过上面的点击获取经纬度坐标,实时添加标记 // 通过设置 offset 来添加偏移量 offset: new AMap.Pixel(-26, -54), }); marker.setMap(map); } // 第二种 直接写死 position 的经纬度值 /*const marker = new AMap.Marker({ icon: "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png", position: [113.808299,34.791787], // 通过设置 offset 来添加偏移量 offset: new AMap.Pixel(-26, -54), }); marker.setMap(map);*/ // 折线 function addPolyLine() { const polyline = new AMap.Polyline({ path: path.value, isOutline: true, outlineColor: "#ffeeff", borderWeight: 1, strokeColor: "#3366FF", strokeOpacity: 0.6, strokeWeight: 5, // 折线样式还支持 'dashed' strokeStyle: "solid", // strokeStyle是dashed时有效 // strokeDasharray: [10, 5], lineJoin: "round", lineCap: "round", zIndex: 50, }); map.add([polyline]); } }).catch(e=>{ console.log(e); })}initMap()</script><style>#container{ padding:0px; margin: 0px; width: 100%; height: 800px;}</style>地图插件效果图:实例化点标记 :

        第一种方式效果:

         第二种方式效果:

 矢量图 --> 折线:

本文链接地址:https://www.jiuchutong.com/zhishi/298570.html 转载请保留说明!

上一篇:nodejs安装和环境配置-Windows(nodejs安装及环境配置win10)

下一篇:玩转ChatGPT:中科院ChatGPT Academic项目部署与测评

  • 怎样做好微博推广增加10万+粉丝(怎样做好微博推广)

    怎样做好微博推广增加10万+粉丝(怎样做好微博推广)

  • 支付宝钱管家的钱怎么提出来(支付宝钱管家的钱怎么取出)

    支付宝钱管家的钱怎么提出来(支付宝钱管家的钱怎么取出)

  • p40pro的微信视频可以打开美颜吗(p40pro微信视频丑)

    p40pro的微信视频可以打开美颜吗(p40pro微信视频丑)

  • 电脑保留个人数据重置(电脑保留个人文件是哪些)

    电脑保留个人数据重置(电脑保留个人文件是哪些)

  • 怎样设置微信背景墙(怎样设置微信背景音乐铃声)

    怎样设置微信背景墙(怎样设置微信背景音乐铃声)

  • 淘宝退货必须用菜鸟裹裹吗(淘宝退货必须用自己的淘宝吗)

    淘宝退货必须用菜鸟裹裹吗(淘宝退货必须用自己的淘宝吗)

  • 电脑学习通有摄像头吗

    电脑学习通有摄像头吗

  • word是什么公司生产的(word是什么软件)

    word是什么公司生产的(word是什么软件)

  • qq随缘匹配是双向的吗(qq里的随缘匹配怎么都是加大号的)

    qq随缘匹配是双向的吗(qq里的随缘匹配怎么都是加大号的)

  • 电脑自带录屏保存在哪(电脑自带录屏保存位置怎么改)

    电脑自带录屏保存在哪(电脑自带录屏保存位置怎么改)

  • 8t硬盘实际容量是多少G(8t硬盘有多重)

    8t硬盘实际容量是多少G(8t硬盘有多重)

  • 红米m1908c3ic是什么型号(红米m1908c3ke型号)

    红米m1908c3ic是什么型号(红米m1908c3ke型号)

  • 优酷怎么看本地视频文件(优酷怎么看本地文件)

    优酷怎么看本地视频文件(优酷怎么看本地文件)

  • iphone无服务怎么解决(iphone无服务怎么弄)

    iphone无服务怎么解决(iphone无服务怎么弄)

  • 手机加速球怎么弄出来(手机加速球怎么关闭)

    手机加速球怎么弄出来(手机加速球怎么关闭)

  • 手机能做ppt吗(苹果手机能做ppt吗)

    手机能做ppt吗(苹果手机能做ppt吗)

  • 携程不用优享套餐怎么操作(携程优享服务费怎么退)

    携程不用优享套餐怎么操作(携程优享服务费怎么退)

  • 抖音资料为什么被锁定(抖音资料为什么暂时被锁定)

    抖音资料为什么被锁定(抖音资料为什么暂时被锁定)

  • 怎样查看我的免拼卡(怎样查看我的免密支付)

    怎样查看我的免拼卡(怎样查看我的免密支付)

  • 内存g和gb一样吗(内存g和内存gb哪个更大)

    内存g和gb一样吗(内存g和内存gb哪个更大)

  • 苹果5ge什么意思(苹果5g是)

    苹果5ge什么意思(苹果5g是)

  • iphonexr可以显示网速吗(苹果xr可以显示电池百分比吗)

    iphonexr可以显示网速吗(苹果xr可以显示电池百分比吗)

  • qq亲密关系怎么绑定(qq亲密关系怎么解除)

    qq亲密关系怎么绑定(qq亲密关系怎么解除)

  • 手机腾讯视频怎么保存本地(手机腾讯视频怎么微信扫码登录)

    手机腾讯视频怎么保存本地(手机腾讯视频怎么微信扫码登录)

  • 看不见的符号复制(看不见的符号复制,取名必用)

    看不见的符号复制(看不见的符号复制,取名必用)

  • 苹果怎么全部删除信息(苹果怎么全部删除)

    苹果怎么全部删除信息(苹果怎么全部删除)

  • 分公司撤销跨区域转固定资产到总公司
  • 保理公司会计核算讲解
  • 企业收到税收返还会计分录
  • 新政府会计制度下属于负债类科目的是
  • 教育费附加可以扣除吗
  • 年前采购
  • 长期股权投资的初始投资成本
  • 多项固定资产能否合并入账
  • 货物出口到保税区复进口
  • 新准则前期差错更正
  • 维修变压器的维修方法
  • 公司投资股票有风险吗
  • 公司开发票就会报税吗?
  • 银票贴现需要银行授信吗
  • 工资报税怎么报的原则
  • 核定征收分几种
  • 弥补以前年度亏损从哪里取数
  • 预付的货款可以计入应付账款吗
  • 供热企业所使用的燃气
  • 组织员工出游注意事项
  • 折旧计算方法举例
  • 季度所得税计算方法
  • 资产负债表其他流动资产计算公式
  • 支付宝安全控件是什么
  • 如何更换电脑开机动画
  • laravel如何使用前端的纯静态页
  • 网络层IP协议的配套协议有哪些
  • 企业的存货按计划成本核算
  • 一般纳税人简易计税会计分录
  • 机票的退票费可以开具发票吗
  • reset fields
  • 编译安装和普通安装
  • uniapp dom操作
  • Vue3通透教程【一】Vue3现状—必然趋势?
  • vue中computed作用
  • web系统的安全现状
  • java面试题及答案下载
  • 投资别人公司的注意事项
  • 物流企业财务流程
  • 融资租赁的固定资产
  • 公司给员工交社保对公司有什么好处
  • 健身房注册公司能注册医疗吗?
  • 没有发票的费用支出怎么入账
  • mysql的主从
  • 在建工程如何转固
  • 有进项发票没有销项发票怎样做账
  • 企业所得税季度预缴纳税申报表
  • 往酒吧送酒怎么样
  • 销售货物如何写凭证
  • 减值准备减少记哪方
  • 知识产权fa
  • 上年多计提的费用,今年如何记账
  • 出售未到折旧年金怎么算
  • 电影赠票怎么用
  • 折旧计入主营业务成本的情况
  • 租用的办公室装修费用怎么入账
  • 收到供应商赠送原材料
  • 如何给初建单位发邮件
  • 会计基础知识必背100题
  • mysql读写分离实现原理
  • innodb 结构
  • mac变得很卡很慢
  • solaris配置ip地址
  • window照片无法预览
  • xp系统如何添加启动项
  • centos查看硬件设备
  • linux 压缩rar
  • 用批处理删除盘符
  • Node.js中的全局对象有
  • android基础知识点
  • javascript字符
  • java语言基于对象
  • JavaScript和HTML DOM的区别与联系及Javascript和DOM的关系
  • 表单中的单选框
  • 北京朝阳地税大厅电话
  • 江西省税务局官网查询系统
  • 增值税是要上交给国家的吗?
  • 税务有问题会罚多少钱?
  • 证券行业的税务问题
  • 推动税务系统全面从严
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设