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

  • steam全屏怎么调成窗口(steam全屏怎么调成窗口快捷键)

    steam全屏怎么调成窗口(steam全屏怎么调成窗口快捷键)

  • 苹果手机晚上拍视频很暗可以调吗(苹果手机晚上拍视频很暗,可以调吗)

    苹果手机晚上拍视频很暗可以调吗(苹果手机晚上拍视频很暗,可以调吗)

  • 苹果手机冒号怎么打(苹果手机冒号怎样打出来)

    苹果手机冒号怎么打(苹果手机冒号怎样打出来)

  • 怎么缩小表格的行间距(怎么缩小表格的高度)

    怎么缩小表格的行间距(怎么缩小表格的高度)

  • 红米k20Pro屏幕材质(红米k20pro屏幕材质)

    红米k20Pro屏幕材质(红米k20pro屏幕材质)

  • 手机微信可以分享屏幕吗(手机微信可以分三个吗)

    手机微信可以分享屏幕吗(手机微信可以分三个吗)

  • 华为20Pro呼叫转移在哪设置(华为20呼叫转移)

    华为20Pro呼叫转移在哪设置(华为20呼叫转移)

  • 华为快充多少w(华为快充多少w比较好)

    华为快充多少w(华为快充多少w比较好)

  • 移动宽带没有路由器可以上网吗(移动宽带没有路由器怎么回事啊)

    移动宽带没有路由器可以上网吗(移动宽带没有路由器怎么回事啊)

  • 软件不允许截屏怎么办(软件不允许截屏和录屏怎么办)

    软件不允许截屏怎么办(软件不允许截屏和录屏怎么办)

  • 惠普打印机加墨后还是提示不足(惠普打印机加墨后怎么操作才能打印)

    惠普打印机加墨后还是提示不足(惠普打印机加墨后怎么操作才能打印)

  • 微型计算机的主要功能(微型计算机的主机由运算器和控制器组成)

    微型计算机的主要功能(微型计算机的主机由运算器和控制器组成)

  • 苹果怎么测试屏幕灵敏度(苹果怎么测试屏幕触摸不灵敏)

    苹果怎么测试屏幕灵敏度(苹果怎么测试屏幕触摸不灵敏)

  • w10怎么切换登录账号(windows10怎么切换用户)

    w10怎么切换登录账号(windows10怎么切换用户)

  • 手机wps怎么做封面(手机wps怎样做封面)

    手机wps怎么做封面(手机wps怎样做封面)

  • 怎么关闭b站直播送礼(怎么关闭b站直播礼物)

    怎么关闭b站直播送礼(怎么关闭b站直播礼物)

  • 什么叫区块链技术(什么叫区块链技术视频)

    什么叫区块链技术(什么叫区块链技术视频)

  • 苹果x可以双卡吗(苹果x可以双卡双待吗手机)

    苹果x可以双卡吗(苹果x可以双卡双待吗手机)

  • 华为mate30是不是5g手机(华为手机系列mate30)

    华为mate30是不是5g手机(华为手机系列mate30)

  • 美国版抖音叫什么(美国抖音app叫什么)

    美国版抖音叫什么(美国抖音app叫什么)

  • 华为p30pro带膜吗(华为p30pro买来时自带保护膜吗)

    华为p30pro带膜吗(华为p30pro买来时自带保护膜吗)

  • wetool怎么加人(wetool怎么加群)

    wetool怎么加人(wetool怎么加群)

  • 怎么用ps取消参考线(ps怎么一键关闭参考线)

    怎么用ps取消参考线(ps怎么一键关闭参考线)

  • 织梦DedeCMS面包屑导航“当前位置”去掉最后一个符号的方法(织梦安装详细教程)

    织梦DedeCMS面包屑导航“当前位置”去掉最后一个符号的方法(织梦安装详细教程)

  • 一般纳税人的认定时间
  • 农产品进项税额转出怎么算
  • 递延收益所得税负债
  • 土地使用税是新增税吗
  • 某项目全部投资资金的40%由银行贷款
  • 零余额账户出纳做什么
  • 润滑油怎么做账务处理
  • 怎么知道对方的支付宝账号
  • 三栏式明细账月结
  • 一般纳税人销售自己使用过的汽车
  • 固定资产清理期末可以有余额吗
  • 固定资产后续支出资本化和费用化
  • 销售折扣怎么开
  • 进项抵欠税相关政策
  • 外商企业所得税可享受什么优惠政策
  • 招待费的进项
  • 保本型理财产品推荐
  • 个人所得税0申报操作流程
  • 注销一定要去营业厅吗
  • 288000元大写怎么写
  • 毛利润率的计算公式举例
  • 资产收购账务处理
  • 营改增后的税率
  • 个税申报密码是什么意思
  • 购物卡发票能否抵扣
  • safari下载的文件怎么删除
  • 季度资产总额怎么填写
  • linux grep显示行数
  • php中如何使用session
  • 个税返还会计政策
  • 怎么扣除税费
  • php 数组定义
  • php怎么上传图片
  • phpfilter
  • php框架开发教程
  • 主营业务毛利率公式
  • php数字增1
  • html+css+js网页设计期末作业付源码
  • css基础入门
  • 已经申报过的个税在哪里查看
  • python字符串中变量替换
  • 防伪税控系统该如何操作
  • 个体工商户该如何开发票
  • 帝国cms为什么安装不了
  • 保障金计入什么科目
  • python怎么访问属性
  • 清算期间还需要报税吗
  • 小规模纳税人的企业所得税怎么算
  • 原始凭证分割单可以入账么
  • 母公司吸收合并全资子公司
  • 注册资金如何使用
  • 燃气费计入什么科目
  • 小微企业所得税优惠政策最新2023
  • 一般纳税人简易征收的适用范围
  • 应纳税的物品有哪些
  • 个人所得税率怎么退
  • 私车公用的风险防范
  • 进项发票认证后暂不抵扣
  • 管理费用如何冲减
  • 已经认证抵扣的发票,要退回,怎么处理
  • 股东之间股权转让的税务处理
  • 协作费用
  • 外出参加会议费用怎么做账
  • 个人往对公账户上存款怎么存
  • 本年利润到年末还有余额吗
  • 对公账户的钱可以花吗
  • 往来是啥意思
  • 数据库日期要加引号吗
  • mysql中索引有什么用
  • win10系统设置快捷键
  • frontpage软件
  • linux修改环境变量后需要重启吗
  • win8怎么切换界面
  • linux shell $1
  • Linux进程间通信——使用流套接字
  • Android屏幕适配分屏
  • 山东省省级政务服务区有哪些
  • 社保欠缴可以放弃吗
  • 北京企业所得税汇算清缴时间
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设