腾讯地图demo,改正确的key即可用

<!DOCTYPE html>
<html><head><meta charset="UTF-8"><title>腾讯地图</title><meta content="width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no"name="viewport">
</head>
<script src="../js/vue.js"></script>
<script charset="utf-8" type="text/javascript"src="https://res2.wx.qq.com/open/js/jweixin-1.4.0.js?v=202004246"></script>
<script charset="utf-8" src="https://mapapi.qq.com/c/=/jsapi_v2/2/4/130/main.js,jsapi_v2/2/4/130/mods/convertor.js"type="text/javascript"></script>
<!-- key 需要自己申请 -->
<script charset="utf-8" src="https://map.qq.com/api/js?v=2.exp&key=XXXXXXXXXXXXXXXXXXXXXXXXXXX"type="text/javascript"></script>
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script><body><div id="vm"><!--地图 --><div id="map-box" v-show="mdMapShow"><div class="page-store-map"><!-- 1 搜索地点 --><div class="search-place-box"><div class="search-place-bg" style="display: ;"><svg t="1574479404611" viewBox="0 0 1024 1024" version="1.1"xmlns="http://www.w3.org/2000/svg" p-id="1224" data-spm-anchor-id="a313x.7781069.0.i1" width="26"height="26" class="icon"><pathd="M1011.369332 960.985828 838.196247 775.139096c70.193689-84.783988 108.795868-190.480262 108.795868-301.721833 0-261.016759-211.775264-473.417263-472.103338-473.417263-260.252349 0-472.030683 212.362642-472.030683 473.417263 0 261.041318 211.778334 473.40089 472.064452 473.40089 68.193125-0.038886 133.954875-14.310937 195.437158-42.384319 18.262946-8.343015 26.319435-29.950126 18.010189-48.223305-8.311293-18.352997-29.960359-26.472931-48.080042-18.063401-52.039213 23.743774-107.667162 35.799344-165.402097 35.840276C254.653841 873.986381 75.483158 694.290743 75.483158 473.417263c0-220.8612 179.164542-400.583444 399.405619-400.583444 220.274846 0 399.476227 179.695638 399.476227 400.583444 0 103.975073-39.546691 202.480574-111.302969 277.386588-13.901615 14.496156-13.429871 37.544081 0.980327 51.501978 1.089821 1.063215 2.509147 1.458211 3.745301 2.362814 0.985444 1.455141 1.489934 3.134387 2.720971 4.446265l187.807387 201.551412c7.123234 7.673773 16.812921 11.543917 26.508747 11.543917 8.893554 0 17.793248-3.241834 24.802896-9.852392C1024.260943 998.714104 1025.059122 975.666178 1011.369332 960.985828L1011.369332 960.985828 1011.369332 960.985828zM1011.369332 960.985828"p-id="1225" fill="#999999"></path></svg><span>搜索地点</span></div><input type="search" v-model="currentAddress" :class="{ isTransparent: currentAddress == '' }"v-on:keyup.enter="searchAddress()"></div><!-- 2 输入经纬度 --><div class="search-jwd-box"><input maxlength="20" type="text" id="longitude" v-model="currentLong" placeholder="请输入经度"><input maxlength="20" type="text" id="latitude" v-model="currentLat" placeholder="请输入纬度"><input type="button" value="搜索" v-on:click="searchLocationByLongLat"></div><!-- 3 地图显示 --><div id="mapContainer" style="height: 250px; background-color: #ccc;"></div><!-- 4 搜索出来的列表 --><ul class="lacation-list"><li v-for="(position, index) in positionList" :key="index" :class="position.id == activeId ? 'active' : ''"v-on:click="changeActiveId(position.id, position.latLng)"><h3>{{ position.name }}</h3><p>{{ position.address }}</p></li></ul></div></div></div><script>var vm = new Vue({el: '#vm',data: {province: {value: 7,name: '广东省'},city: {value: 8,name: '广州市'},district: {value: 10,name: '白云区'},mdMapShow: true,markers: [],currentAddress: '', //搜索的地点currentLat: '',currentLong: '',positionList: [],activeId: '',searchKey: '瑶台'},created() {},mounted() {this.mapInit(); // 地图初始化this.searchAddress(this.searchKey);},computed: {},watch: {},methods: {// 搜索地址searchAddress(searchKey) {// 设置搜索的范围、关键字等属性、页码、每页数量let keyword;if (searchKey) {this.currentAddress = searchKey;}keyword = this.currentAddress;if (keyword.trim() == '') {return;}let city = this.city.name;let pageIndex = 0;let pageCapacity = 20;this.clearOverlays(this.markers);// 根据输入的城市设置搜索范围this.searchService.setLocation(city);// 设置搜索页码this.searchService.setPageIndex(pageIndex);// 设置每页的结果数this.searchService.setPageCapacity(pageCapacity);// 根据输入的关键字在搜索范围内检索this.searchService.search(keyword);},searchLocationByLongLat() { // 根据经纬度搜索地址let _this = this;let { currentLong: Longitude, currentLat: Latitude } = this;// 经纬度验证if (/^[\-]?[1-9]\d{0,2}\.[0-9]+$/.test(Longitude) && /^[\-]?[1-9]\d{0,1}\.[0-9]+$/.test(Latitude)) {if (!/^[\-]?[1-9]\d{0,2}\.[0-9]{4,}$/.test(Longitude) || !/^[\-]?[1-9]\d{0,1}\.[0-9]{4,}$/.test(Latitude)) {_this.$toast('经纬度需精确到小数点后至少4位。');return;} else if (Longitude > 180 || Latitude > 90) {_this.$toast('纬度、经度格式不正确!纬度范围-90~90,经度范围-180~180。');return;}} else {if (!/^[\-]?0\.[0-9]{4,}$/.test(Longitude) || !/^[\-]?0\.[0-9]{4,}$/.test(Latitude)) {_this.$toast('纬度、经度格式不正确!纬度范围-90~90,经度范围-180~180。');return;}}var isScoped = 2;$.ajax({url: 'https://apis.map.qq.com/ws/geocoder/v1',data: {location: Latitude + ',' + Longitude,get_poi: 0,key: 'JHIBZ-CTWR5-UJFIK-Q4HGE-4Z7XX-C7BLV', //改为自己申请的keyoutput: 'jsonp'},async: false,dataType: 'jsonp',success: function (res) {if (res.status == 0) {var returnData = res.result.address_component;if (returnData.hasOwnProperty('province')) { // 中国if ((returnData.province.indexOf(_this.sheng) !== -1) && (returnData.city.indexOf(_this.shi) !== -1)) { // 省、市isScoped = 1;} else { // 香港澳门台湾if ((_this.sheng.indexOf('香港') !== -1) && (returnData.province.indexOf('香港') !== -1)) {isScoped = 1;} else if ((_this.sheng.indexOf('澳门') !== -1) && (returnData.province.indexOf('澳门') !== -1)) {isScoped = 1;} else if ((_this.sheng.indexOf('台湾') !== -1) && (returnData.province.indexOf('台湾') !== -1)) {isScoped = 1;} else {isScoped = 0;}}} else {if (_this.sheng.indexOf('海外') !== -1) {isScoped = 3; // 是海外} else {isScoped = 0; // 海外经纬度,但选择的不是海外}}} else {//请求来源未被授权,此次请求无来源信息等isScoped = 2;alert(res.message);}if (isScoped == 0) {alert('所输入的经纬度和地址不在同一范围内,请检查后重新输入。');return;}if (isScoped == 2) {return;}console.log(res.result);_this.activeId = 'abc';_this.positionList = [{address: res.result.address,name: res.result.formatted_addresses.recommend,id: 'abc',latLng: {lat: Latitude,lng: Longitude}}];console.log(_this.positionList);var latLng = new qq.maps.LatLng(Latitude, Longitude);// 调用获取位置方法_this.geocoder.getAddress(latLng);}});},mapInit() {let _this = this;// 初始地址var center = new qq.maps.LatLng(23.12463, 113.36199);_this.map = new qq.maps.Map(document.getElementById('mapContainer'), {center: center,zoom: 15});// 设置Poi检索服务,用于本地检索、周边检索_this.searchService = new qq.maps.SearchService({// 检索成功的回调函数complete: function (results) {// 设置回调函数参数var pois = results.detail.pois;var latlngBounds = new qq.maps.LatLngBounds();var positionList = [];for (var i = 0, l = pois.length; i < l; i++) {var poi = pois[i];// 经纬度至少要4位小数if (poi.latLng.lng.toString().split(".")[1].length < 4) {console.log(poi.latLng.lng.toString().split(".")[1].length);poi.latLng.lng = poi.latLng.lng.toFixed(4);}if (poi.latLng.lat.toString().split(".")[1].length < 4) {poi.latLng.lat = poi.latLng.lat.toFixed(4);}if (i == 0) { // 只标注第一个点// 扩展边界范围,用来包含搜索到的Poi点latlngBounds.extend(poi.latLng);_this.currentLat = poi.latLng.lat;_this.currentLong = poi.latLng.lng;var marker = new qq.maps.Marker({map: _this.map});marker.setPosition(pois[0].latLng);_this.markers.push(marker);_this.activeId = pois[0].id}positionList.push({address: poi.address || '',name: poi.name || '',id: poi.id,latLng: poi.latLng || { lat: '', lng: '' }});}_this.positionList = positionList; // 更新一下视图层的列表// 调整地图视野_this.map.fitBounds(latlngBounds);},// 若服务请求失败,则运行以下函数error: function () {console.log('搜索不到结果');}});// 调用地址解析类_this.geocoder = new qq.maps.Geocoder({complete: function (result) {_this.clearOverlays(_this.markers);// 调整地图包含该点var latlngBounds = new qq.maps.LatLngBounds();latlngBounds.extend(result.detail.location);_this.map.fitBounds(latlngBounds);var marker = new qq.maps.Marker({map: _this.map});marker.setPosition(result.detail.location);_this.markers.push(marker);}});},clearOverlays(overlays) { // 除地图上的markervar overlay;while ((overlay = overlays.pop())) {overlay.setMap(null);}},changeActiveId(id, latLng) {var _this = this;this.activeId = id;this.clearOverlays(this.markers);this.currentLat = latLng.lat;this.currentLong = latLng.lng;// 调整地图包含该点var latlngBounds = new qq.maps.LatLngBounds();latlngBounds.extend(latLng);this.map.fitBounds(latlngBounds);var marker = new qq.maps.Marker({map: _this.map});marker.setPosition(latLng);this.markers.push(marker);},toStoreRegister() { // 确定修改// 要拿来覆盖的数据有: 地址,以搜索列表的结果为准,不以输入框的结果为准// 若是搜索地址,则搜索结果的经纬度会自动代入经纬度输入框// 若是搜索经纬度,则搜索结果只有一个点,并且经纬度就是输入框的值// 直接取输入框的经纬度来用,防止用户输入了经纬度不点击按钮,将经纬度是否在省市区内的逻辑改到提交那里。let { positionList, currentLat, currentLong } = this;// 拿到当前active的搜索结果的地址,若列表为空,则不覆盖原来的地址for (var i = 0; i < positionList.length; i++) {if (positionList[i].id == this.activeId) {// console.log(positionList[i].latLng.lat, positionList[i].latLng.lng);// 去除省市区var myBossAddress = positionList[i].address + positionList[i].name;var shengshiqu = this.sheng + this.shi + this.qu;var shengshi = this.sheng + this.shi;if (myBossAddress.includes(shengshiqu)) {myBossAddress = myBossAddress.replace(shengshiqu, '');} else if (myBossAddress.includes(shengshi)) {myBossAddress = myBossAddress.replace(shengshi, '');}console.log(myBossAddress, shengshiqu);this.$store.commit('changeBossAddress', myBossAddress);break;}}// 直接取输入框的经纬度来覆盖this.$store.commit('changeBossLatLong', { bossLatitude: currentLat, bossLongitude: currentLong });// 隐藏当前组件this.$parent.isShowStoreMap = false;console.log(this.$store.state.bossAddress, this.$store.state.bossLatitude, this.$store.state.bossLongitude);this.$setTitle("注册门店");},}});</script><style>[v-cloak] {display: none;}html {overflow-x: auto;overflow-y: scroll;}body,dl,dt,dd,ul,ol,li,pre,form,fieldset,input,p,blockquote,th,td {font-weight: 400;margin: 0;padding: 0;}h1,h2,h3,h4,h4,h5 {margin: 0;padding: 0;}#map-box {position: relative;z-index: 1000;}#map-box .page-store-map {position: fixed;top: 0;left: 0;right: 0;bottom: 0;z-index: 100;display: flex;flex-direction: column;background-color: #fff;}#map-box .page-store-map .search-place-box {width: 100%;height: 50px;position: relative;}#map-box .page-store-map .search-place-box .search-place-bg {margin: 10px;width: calc(100% - 20px);height: 30px;position: absolute;background-color: #F0F0F0;line-height: 30px;text-align: center;color: #ABABAB;font-size: 14px;border-radius: 5px;z-index: 1;display: flex;justify-content: center;align-items: center;}#map-box .page-store-map .search-place-box .search-place-bg svg {width: 13px;height: 13px;margin-right: 16px;margin-top: -1px;}#map-box .page-store-map .search-place-box input {margin: 10px;height: 30px;width: calc(100% - 20px);position: absolute;z-index: 2;text-align: center;font-size: 14px;padding: 0 10px;line-height: normal;border-radius: 5px;background-color: #fff;box-sizing: border-box;}#map-box .page-store-map .search-place-box input.isTransparent {background-color: transparent;}#map-box .page-store-map .search-jwd-box {height: 30px;padding: 10px 0 10px 15px;background-color: #F7F7F7;display: flex;justify-content: space-between;border-bottom: 5px solid #fff;}#map-box .page-store-map .search-jwd-box input {background-color: #fff;border-radius: 3px;box-sizing: border-box;border: 1px solid #E7E7E7;}#map-box .page-store-map .search-jwd-box input:first-child {padding: 0 10px;width: calc((100% - 100px)/2);}#map-box .page-store-map .search-jwd-box input:nth-child(2) {padding: 0 10px;width: calc((100% - 100px)/2);}#map-box .page-store-map .search-jwd-box input:last-child {width: 70px;border-color: #3C77DA;color: #3C77DA;margin-right: 15px;text-align: center;}#map-box .page-store-map #container {height: 250px;}#map-box .page-store-map ul {margin-top: 10px;padding-bottom: 10px;flex: 1;overflow-y: auto;}#map-box .page-store-map ul li {margin-bottom: 10px;padding-left: 30px;padding-right: 10px;position: relative;}#map-box .page-store-map ul li h3 {line-height: 20px;color: #333;font-size: 14px;}#map-box .page-store-map ul li p {line-height: 15px;color: #999;font-size: 12px;}#map-box .page-store-map ul li:last-child {margin-bottom: 0;}#map-box .page-store-map ul li:after {content: "";display: block;width: 12px;height: 12px;border: 1px solid #ccc;border-radius: 50%;position: absolute;top: 10px;left: 10px;}#map-box .page-store-map ul li.active:after {top: 10px;border-radius: 0;width: 13px;height: 15px;border: 0 none;background: url() no-repeat;background-size: contain;}#map-box .page-store-map .submit-box {height: 60px;display: flex;justify-content: space-between;padding: 0 15px;align-items: center;box-shadow: 0px 0px 8px 0px rgba(0, 0, 0, 0.1);}#map-box .page-store-map .submit-box div {margin: 10px;box-sizing: border-box;font-size: 15px;height: 32px;line-height: 32px;text-align: center;border-radius: 15px;}#map-box .page-store-map .submit-box .fanhui {flex: 1;border: 1px solid #DEDEDE;color: #333;}#map-box .page-store-map .submit-box .queding {flex: 2;background-color: #2DC927;color: #fff;font-weight: bold;}.icon-map {display: inline-block;vertical-align: middle;width: 15px;height: 21px;background: url() no-repeat;background-size: contain;}</style></body></html>

vue版本--腾讯地图demo,可搜索关键字和经纬度,显示地图和搜索结果列表相关推荐

  1. 仿 淘宝搜索栏,实现 用户输入搜索关键字时可以显示 搜索提示 的效果 Ajax

    要实现的 UI 功能 依赖文件: jQuery https://jquery.com/ art-template 模板引擎 https://aui.github.io/art-template/ 实现 ...

  2. 高德地图的基础使用(一)显示地图

    (注:先注册,高德开发者 ) 1.地址:https://lbs.amap.com/ 2.控制台 3.创建新应用 4.编辑信息 4.1 获取安全码SHA1(命令提示符方式:win+r - cmd ) c ...

  3. 根据经纬度显示地图轨迹

    后端代码 public boolean saveCarGPSData(CarGPSReqVo carGPSReqVo) {Map<String,String> params=new Has ...

  4. php文件里搜索关键字,php - PHP从文本文件中搜索关键字(Action'),使用该关键字打印所有行,然后计算打印的行数 - SO中文参考 - www.soinside.com...

    所以我刚开始学习PHP,我想从文本文件中搜索某个关键字(Action'),然后用关键字打印所有行,然后计算所有打印的行. 这是我到目前为止所拥有的: $searchfor = 'ERR:'; echo ...

  5. 手机端GSP地图的定位 并且在网页上显示地图的轨迹

    百度地图定位手机端功能开发: 第一步:申请百度的开发者密钥http://developer.baidu.com/map/android-mobile-apply-key.htm 申请到开发API的ke ...

  6. php记录搜索关键字_PHP记录搜索引擎来路以及搜索输入的关键字

    利用php记录搜索引擎的来路以及用户搜索输入的关键字,代码如下: '百度','google.'=>'谷歌','soso.'=>'搜搜','sogou.'=>'搜狗','www.so. ...

  7. mysql全库搜索关键字_MS SQL SERVER 全库搜索

    定位单个数据库中等于某值的记录所在的表和列. 第13行的xtype=167代表只搜索数据类型是varchar的列. 第18行就是根据关键字具体过滤列的数据. SQL Server create pro ...

  8. html添加地图坐标,肿么把用html经纬度在地图上标记

    经纬度有相差那个是正常的,用户用浏览打开时定位的IP不是用户本身电脑的IP,而是公网出口的IP. 简单的说,你用电信上网,那用IP定位到的可能是你附近的某个电信大楼. 代码网上都有,出错的话你可以比对 ...

  9. 谷歌手机地图中文java_谷歌地图开发(1)使用MapView显示地图

    一.使用MapView 时,要和 MapActivity 联合起来使用,因为在 MapActivity 中,要连接底层 网络 . 步骤 : (1)添加 MapView 组件 android:apiKe ...

最新文章

  1. IB网络用户数量超过私有网络近4倍
  2. android系统sharedUserId: SYSTEM_UID+PHONE_UID+BLUETOOH_UID+LOG_UID+NFC_UID
  3. C#根据字节数截取字符串【转载】
  4. [胡思乱想]网络游戏与社会资源公平分配
  5. oracle配置ipv6_配置 IPv6 接口
  6. Radar altimeters and laser altimeters
  7. 必学:入行电商产品经理必备知识,原来这么简单
  8. python下stl格式转换off格式
  9. 老徐和阿珍的故事:ArrayList和LinkedList的效率到底哪个高?
  10. WTS:基于Web的Terminal控制台
  11. Double计算精度丢失(金融入门知识点)
  12. Linux下Socket编程之TCP原理
  13. windows下如何查看本机所在局域网内所有可以访问的IP
  14. 安卓商城购物车布局案例
  15. ios 输入法扩展_iOS 11自带输入法新增3个小功能,贴心!
  16. linux传奇私服文件包,传奇私服目录文件结构
  17. 使用conda/pip安装pytorch 0.3.1教程(mac/windos/linux)
  18. linux服务器禁ping
  19. glade java_Gtk+/Glade编程(一)--简介
  20. HashMap深度解释推导

热门文章

  1. WPF 二维码生成器
  2. 水晶报表之分页预留空白方便打印信纸
  3. 微信小游戏 修改appid
  4. echarts初步使用
  5. web zxr10 中兴 路由器_ZXR10路由器基本操作和配置
  6. 案例研究分析:巴基斯坦 ISP 如何通过黑洞路由关闭 YouTube
  7. 视频剪辑小技巧 ,裁切视频部分画面,调整画面尺寸
  8. B站直播:通信工程师考试大科普(下周四)
  9. linux 无线网卡 监听模式,查看无线网卡是否支持监听模式
  10. 管理平台|智慧工地将成为施工界的“扛把子”!