位置: 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项目部署与测评

  • iqoo8pro机身尺寸(iqoo8pro长宽)

    iqoo8pro机身尺寸(iqoo8pro长宽)

  • 抖音可以看给谁送过礼物吗(抖音视频怎么去掉别人的抖音号)

    抖音可以看给谁送过礼物吗(抖音视频怎么去掉别人的抖音号)

  • 快手能用obs直播吗(快手用obs直播会限流吗)

    快手能用obs直播吗(快手用obs直播会限流吗)

  • 苹果手机微信屏幕黑色怎么变过来(苹果手机微信屏幕锁)

    苹果手机微信屏幕黑色怎么变过来(苹果手机微信屏幕锁)

  • 沾沾卡怎么得到的(沾沾卡怎么使用概率高)

    沾沾卡怎么得到的(沾沾卡怎么使用概率高)

  • 网线poe供电用哪根线(poe网线供电用哪两芯)

    网线poe供电用哪根线(poe网线供电用哪两芯)

  • 手机淘宝投诉后在哪里可以看(手机淘宝投诉后怎么撤销)

    手机淘宝投诉后在哪里可以看(手机淘宝投诉后怎么撤销)

  • 华为手表和oppo手机能不能匹配(华为手表和OPPO手表哪个性价比高)

    华为手表和oppo手机能不能匹配(华为手表和OPPO手表哪个性价比高)

  • 抖音像素怎么设置(抖音视频像素怎么调)

    抖音像素怎么设置(抖音视频像素怎么调)

  • 华为p40pro颜色选择(华为p40pro主打颜色)

    华为p40pro颜色选择(华为p40pro主打颜色)

  • 华为nova7pro微信视频有美颜吗(华为nova7pro微信视频怎么开美颜)

    华为nova7pro微信视频有美颜吗(华为nova7pro微信视频怎么开美颜)

  • iphone录屏中途没声音(苹果录屏录了一半不在录了,也没有视频)

    iphone录屏中途没声音(苹果录屏录了一半不在录了,也没有视频)

  • 华为蓝色呼吸灯死机(华为手机呼吸灯蓝色是什么意思)

    华为蓝色呼吸灯死机(华为手机呼吸灯蓝色是什么意思)

  • vivonex3s上市时间(vivonex3s上市时间和价格)

    vivonex3s上市时间(vivonex3s上市时间和价格)

  • b站可以屏蔽tag吗(b站可以屏蔽别人吗)

    b站可以屏蔽tag吗(b站可以屏蔽别人吗)

  • 手机显示3g怎么回事(手机显示3g怎么调成4g)

    手机显示3g怎么回事(手机显示3g怎么调成4g)

  • 如何给文字加双波浪下划线(如何给文字加双下划线)

    如何给文字加双波浪下划线(如何给文字加双下划线)

  • 快充和数据线有关系吗(快充和数据线有关系还是和插头有关系)

    快充和数据线有关系吗(快充和数据线有关系还是和插头有关系)

  • ipadmpgt2cha是什么型号(苹果ipadmpgw2ch/a是什么型号)

    ipadmpgt2cha是什么型号(苹果ipadmpgw2ch/a是什么型号)

  • 荣耀8xmax上市时间(荣耀8xmax什么时候出的)

    荣耀8xmax上市时间(荣耀8xmax什么时候出的)

  • 微信刷脸支付怎么设置(微信刷脸支付怎么开启)

    微信刷脸支付怎么设置(微信刷脸支付怎么开启)

  • 京东预约怎么更改(京东预约怎么改)

    京东预约怎么更改(京东预约怎么改)

  • 抖音注销后的的状态(抖音注销的的7天不能正常身份校验)

    抖音注销后的的状态(抖音注销的的7天不能正常身份校验)

  • 拼多多免拼卡在哪里(拼多多免拼卡在哪里领取)

    拼多多免拼卡在哪里(拼多多免拼卡在哪里领取)

  • 索尼xperia1怎么设置开机动画

    索尼xperia1怎么设置开机动画

  • Redmi K20 Pro的GPU是那种

    Redmi K20 Pro的GPU是那种

  • 手机图虫怎么发视频(图虫发图片有啥要求)

    手机图虫怎么发视频(图虫发图片有啥要求)

  • Win10中macos big sur虚拟机无法连接网络怎么办?

    Win10中macos big sur虚拟机无法连接网络怎么办?

  • 报表中的存货是如何填报的
  • 租金没有发票可以入账吗
  • 劳务派遣代发工资开票
  • 电子发票与纸质发票具有同等效力
  • 高温补贴能以别的形式发放吗
  • 动漫产业增值税优惠政策
  • 押金可以抵扣吗
  • 股东取得利息收入如何纳税
  • 股东借款可以免增值税吗
  • 出口押汇与打包押汇区别
  • 管道租赁合同怎么写
  • 技术服务从哪年开始实施
  • 增值税发票开票限额怎么申请?
  • 保安服务费可以开具专票吗
  • 个人两处以上所得经营所得怎么申报
  • 快递公司怎么结算
  • 3%增值税专用发票可以抵扣多少
  • 发票报销增值税
  • 本年利润的借贷双方表示什么
  • 工商注册需要提供什么
  • 企业研发过程中特殊收入的会计处理
  • coloros12对比鸿蒙
  • 公司长期贷款
  • rpcclient.exe - rpcclient是什么进程 有什么用
  • 深入浅出stm8
  • vant3.0
  • phpjoin
  • php composer自动加载
  • 固定资产折旧的计算方法
  • 补缴免抵退
  • 公司开发新产品或购买许可证最快的方法是
  • 公司账户的钱怎么少了
  • php的implode函数
  • php二维数组按某个键值排序
  • 一个简单安全的小故事
  • 什么叫非侵入性装置
  • 前端向后端传递对象数组
  • 知识图谱ui
  • php字符串编码转换
  • 货币资金包括哪些方面
  • 银行利息的收入计入什么科目
  • 基本户理财产品有哪些
  • 营改增后的劳务费怎么开
  • SQL Server 2012 FileTable 新特性详解
  • 理解的近义词
  • 小规模纳税人如何升级为一般纳税人
  • 没有发票可以先付款吗
  • 跨年已付款发票未到会计分录
  • 固定资产如何计提折旧
  • 设备安装业绩
  • 应付账款一直挂在账上会有问题吗
  • 进项转出的原因是什么
  • 公司多出来的钱怎么办
  • 本月增加无形资产什么时候计提折旧
  • 印花税的征税对象有哪些
  • 预包装食品加工及销售营业执照图片
  • 小规模纳税人如何缴纳企业所得税
  • 年终奖和工资一起发吗
  • 怎么建立起来的
  • 修改远程桌面端口命令是什么
  • bios如何设置关机键开机
  • win7鼠标点了没反应
  • win8手机版
  • Ubuntu Linux 7.04QQ、MSN 安装和使用方法
  • centos怎么设置
  • quickres.exe - quickres是什么进程 作用是什么
  • win7激活工具怎么使用
  • win10家庭版教程
  • win10搜索设置选项
  • jquery-file-upload 文件上传带进度条效果
  • ini文件编辑
  • shell编程简单实例
  • node.js deno
  • 创建一个新用户user1,设置其主目录为/home/user1:
  • 狗刨好学吗
  • jquery查找当前元素的父元素
  • python 汉诺塔
  • 江苏发票真伪查询网站
  • 苏州公积金密码怎么改
  • 房屋赠与给子女要交多少税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设