腾讯地图 地图选点组件报错:Cannot read property formatted_addresses of undefined的解决

背景

新能源充电项目
后台需要搞个充电桩经纬度选取的基本功能…懒死,找现成先…
找找-----------------呃.地图选点组件
http://lbs.qq.com/webApi/component/componentGuide/componentPicker
好像能用… 用吧… 懒死我得了

问题

什么鬼… TXMAP前端快出来背锅
在这里插入图片描述

先给结论

如图: 腾讯位置服务逆地址解析接口并发配额默认为5, 申请企业开发者可提升到1000,既可直接忽视问题
腾讯位置服务逆地址解析接口并发配额
在这里插入图片描述
在这里插入图片描述

过程

找过去
在这里插入图片描述
格式化下显示
在这里插入图片描述
看情况应该是这个地址解析接口返回的数据机构情况没在TX前端考虑的范畴
在这里插入图片描述
断个点看看
在这里插入图片描述
在这里插入图片描述

擦咧… 真是
在这里插入图片描述

解决方法

1. 老老实实去申请对应接口的配额

2. 不爽,我要挪移

2.1 扒拉主html

a.) 查看 https://3gimg.qq.com/lightmap/components/locationPicker2/index.html?search=1&type=1&key=you key&referer=myapp 源文件内容, 拷贝下来存到自己项目某个位置 locationPicker.html (我调本地文件还不行吗)
a.) 替换掉其中所有资源地址为原服务服务器地址对应地址
b.) 修改 seajs 的 base 为 ‘./location-picker/’ (逼它调本地文件)
c.) 下载 https://3gimg.qq.com/lightmap/components/locationPicker2/js/index-6781e3253a.js丢到 location-picker 目录下

目录结构和名字,文件名等看个人习惯了,我项目后台是VUE全家桶的,我丢这了
在这里插入图片描述
locationPicker.html 中需要具体需要修改:

<!DOCTYPE html>
<html>
    <head lang="zh-CN">
        <script type="text/javascript">
            var StatTimer = (window.StatTimer = {
                _s: new Date().getTime(),
                data: {},
                stub: function(name) {
                    this['data'][name] = (new Date().getTime() - this._s) / 1000;
                }
            });
        </script>
        <meta charset="UTF-8" />
        <meta
            name="viewport"
            content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"
        />
        <meta name="mobile-web-app-capable" content="yes" />
        <meta name="apple-mobile-web-app-capable" content="yes" />
        <meta name="apple-mobile-web-app-status-bar-style" content="black" />
        <meta name="format-detection" content="address=no" />
        <title>地图选点</title>
        <!-- 换掉地址 -->
        <!-- <link rel="stylesheet" type="text/css" href="./css/main-b92af55349.css"> -->
        <link
            rel="stylesheet"
            type="text/css"
            href="//3gimg.qq.com/lightmap/components/locationPicker2/css/main-b92af55349.css"
        />
    </head>
    <body>
        <!-- loading -->
        <div id="loading">
            <!-- 换掉地址 -->
            <!-- <img src="./image/loading.png" width="36" height="36" alt="loading" /> -->
            <img
                src="//3gimg.qq.com/lightmap/components/locationPicker2/image/loading.png"
                width="36"
                height="36"
                alt="loading"
            />
        </div>
        <div id="updating">
            <!-- 换掉地址 -->
            <!-- <img src="./image/loading.png" width="36" height="36" alt="updating" /> -->
            <img
                src="//3gimg.qq.com/lightmap/components/locationPicker2/image/loading.png"
                width="36"
                height="36"
                alt="updating"
            />
        </div>

        <script type="text/javascript">
            StatTimer.stub('geolocation_start');
        </script>
        <!-- 通过 iframe 嵌入前端定位组件 -->
        <iframe
            id="geoPage"
            style="display:none"
            width="0"
            height="0"
            frameborder="0"
            scrolling="no"
            src="https://apis.map.qq.com/tools/geolocation?key=you key&referer=locationPicker"
        >
        <!-- you key 是你的腾讯地图key -->
        </iframe>
        <!-- 定位失败页 -->
        <div id="geoFail" class="hide">
            <div class="error-msg">
                <!-- 换掉地址 -->
                <!-- <img src="./image/warn.png" width="30" height="30" alt="warn" /> -->
                <img
                    src="//3gimg.qq.com/lightmap/components/locationPicker2/image/warn.png"
                    width="30"
                    height="30"
                    alt="warn"
                />
                <span>定位失败,请稍后重试</span>
            </div>
            <a class="refresh-btn" href="javascript:;">重试</a>
        </div>

        <!-- 传递的经纬度不合法提示页 -->
        <div id="locationIllegal" class="hide">
            <div class="error-msg">
                <!-- 换掉地址 -->
                <!-- <img src="./image/warn.png" width="30" height="30" alt="warn" /> -->
                <img
                    src="//3gimg.qq.com/lightmap/components/locationPicker2/image/warn.png"
                    width="30"
                    height="30"
                    alt="warn"
                />
                <span>传递的经纬度不合法</span>
            </div>
        </div>
        <!-- 搜索区域 -->
        <a href="#" id="iosFix"></a>
        <div class="search-wrap init-status">
            <div class="search-bar">
                <form name="poi-search" id="poiSearch" onsubmit="return false;">
                    <input type="search" class="keyword" id="searchword" placeholder=" " />
                    <button type="reset" class="clear-input"></button>
                    <button type="submit" class="submit">搜索</button>
                </form>
                <a class="cancle">取消</a>
            </div>
        </div>
        <!-- 搜索提示区域 -->
        <div class="suggestion-wrap">
            <div id="suggestionScroller" class="suggestion-scroller">
                <div class="poi-list">
                    <ul>
                        <!-- 该区域不仅放搜索提示列表,还放点击搜索后的检索结果列表 -->
                    </ul>
                </div>
                <div class="load-wrap hide">
                    <div class="load-data">
                        <!-- 换掉地址 -->
                        <!-- <img width="24" height="24" src="./image/loadData.png" /> -->
                        <img
                            width="24"
                            height="24"
                            src="//3gimg.qq.com/lightmap/components/locationPicker2/image/loadData.png"
                        />
                        <span>加载中...</span>
                    </div>
                </div>
                <div class="no-more-results hide">
                    <p>亲,没有更多了~</p>
                </div>
            </div>
        </div>

        <!-- 地图区域 -->
        <div class="map-wrap">
            <!-- map地图 -->
            <div id="container">
                <div class="marker">
                    <i></i>
                    <!-- 换掉地址 -->
                    <!-- <img width="26px" height="36px" src="./image/marker.png" /> -->
                    <img
                        width="26px"
                        height="36px"
                        src="//3gimg.qq.com/lightmap/components/locationPicker2/image/marker.png"
                    />
                </div>
                <!-- 返回当前位置 -->
                <div class="go-back-pos"><i></i></div>

                <div id="map-info">
                    <!-- 比例尺 -->
                    <div class="scale">200</div>
                    <div class="qqmap-text-logo"></div>
                </div>

                <div class="to-right">
                    <!-- 缩放按钮 -->
                    <a class="cbutton" id="btn-zoom">
                        <i id="btn-zoom-in" class="icon-zoom-in" data-adtag="zoomin">+</i>
                        <i id="btn-zoom-out" class="icon-zoom-out" data-adtag="zoomout">-</i>
                    </a>
                </div>
            </div>
        </div>

        <!-- poi列表 -->
        <div class="list-wrap">
            <div id="scroller" class="poi-scroller">
                <div id="activePosition" class="active-pos">
                    <h2 class="poi-title"></h2>
                    <p class="poi-address initPos"></p>
                    <span class="poi-latlng"></span>
                    <span class="poi-city"></span>
                    <i class="active"></i>
                </div>
                <div class="poi-list">
                    <ul></ul>
                </div>
                <div class="load-wrap">
                    <div class="load-data">
                        <!-- 换掉地址 -->
                        <!-- <img width="24" height="24" src="/image/loadData.png" /> -->
                        <img
                            width="24"
                            height="24"
                            src="//3gimg.qq.com/lightmap/components/locationPicker2/image/loadData.png"
                        />
                        <span>加载中...</span>
                    </div>
                </div>
                <div class="no-more-results">
                    <p>亲,没有更多了~</p>
                </div>
            </div>
        </div>

        <!-- 换掉地址 -->
        <!-- <script type="text/javascript" src="./js/main-99ae221f02.js"></script> -->
        <script
            type="text/javascript"
            src="//3gimg.qq.com/lightmap/components/locationPicker2/js/main-99ae221f02.js"
        ></script>
        <script src="https://apis.map.qq.com/api/js?v=2.exp&key=VFUBZ-JIR3D-Z2M4H-PPAGG-G5KVQ-S3F2S&callback="></script>
        <script>
            seajs.config({
                // 换自己的目录
                // base: './js/'
                base: './location-picker/'
            });
            seajs.use(['index-6781e3253a.js'], function(View) {
                new View();
            });
        </script>

        <!-- List template -->
        <script id="listTpl" type="text/x-template">
            {{#if list}}
                {{#each list}}
                    <li>
                        <h2 class="poi-title">{{title}}</h2>
                        <p class="poi-address">{{address}}</p>
                        <span class="poi-latlng">{{location.lat}},{{location.lng}}</span>
                        <span class="poi-city">{{ad_info.city}}</span>
                        <i class="active"></i>
                    </li>
                {{/each}}
            {{else}}
                <p class="no-results">o_O出错了~</p>
            {{/if}}
        </script>

        <!-- suggestion template -->
        <script id="sugTpl" type="text/x-template">
            {{#if list}}
                {{#each list}}
                    <li>
                        <p class="item">
                            <span class="poi-title">{{title}}</span>
                            <span class="poi-address">{{address}}</span>
                            <span class="poi-latlng">{{location.lat}},{{location.lng}}</span>
                            <span class="poi-city">{{ad_info.city}}</span>
                        </p>
                    </li>
                {{/each}}
            {{else}}
                {{#if suggestion}}
                    {{#each suggestion}}
                        <li data-lat="{{pointy}}" data-lng="{{pointx}}">
                            <p class="item">
                                <span class="poi-title">{{title}}</span>
                                <span class="poi-address">{{address}}</span>
                                <span class="poi-latlng">{{location.lat}},{{location.lng}}</span>
                                <span class="poi-city">{{city}}</span>
                            </p
                        </li>
                    {{/each}}
                {{/if}}
            {{/if}}
        </script>
        <!-- 统计代码?干掉 -->
        <!-- <script type="text/javascript" src="//pingjs.qq.com/h5/stats.js" name="MTAH5" sid="500153441"></script> -->
    </body>
</html>

d.) 最后的罪魁祸首,改它
在这里插入图片描述
搜索 “formatted_addresses”

var o=e.result.formatted_addresses.recommend

前面加上

if(!e.result) return;var o=e.result.formatted_addresses.recommend

搜索

./image/location.png

替换为

//3gimg.qq.com/lightmap/components/locationPicker2/image/location.png
2.2 使用

http://你web服务地址/locationPicker.html?search=1&type=1&key=you key&referer=myapp

嗯这下可以愉快的玩耍了…

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在Vue中通过iframe调用腾讯地图地图选点组件,并实现反显地点,可以按照以下步骤进行: 1. 在Vue组件中添加一个iframe元素,并设置其src属性为腾讯地图地图选点组件的URL。同时,给iframe添加一个id,以便在后面的代码中可以通过id获取到iframe元素。 ``` <template> <div> <iframe id="map-iframe" src="https://apis.map.qq.com/tools/locpicker?search=1&type=1&key=YOUR_KEY"></iframe> </div> </template> ``` 2. 在Vue组件的mounted生命周期钩子中,给iframe添加一个load事件的监听器。当iframe加载完成后,通过postMessage向iframe发送一个消息,告诉它需要反显地点。 ``` <script> export default { mounted() { const iframe = document.getElementById("map-iframe"); iframe.addEventListener("load", () => { const message = { type: "show", data: { latLng: { lat: 39.916527, lng: 116.397128 } } }; iframe.contentWindow.postMessage(message, "*"); }); window.addEventListener("message", event => { if (event.origin !== "https://apis.map.qq.com") { return; } if (event.data.type === "location") { const location = event.data.data; console.log(location); } }); } }; </script> ``` 3. 在iframe中通过window.addEventListener监听父窗口发送的postMessage消息。当收到show类型的消息后,根据消息中的经纬度信息,在地图上显示一个标记点,并通过Geocoder逆地址解析功能获取反显地址信息。当用户点击标记点时,通过postMessage向父窗口发送一个消息,告诉它选中的地点信息。 ``` <script> window.addEventListener("message", event => { if (event.origin !== "https://apis.map.qq.com") { return; } if (event.data.type === "show") { const map = new qq.maps.Map(document.getElementById("map-container"), { center: new qq.maps.LatLng(event.data.data.latLng.lat, event.data.data.latLng.lng), zoom: 13 }); const marker = new qq.maps.Marker({ position: new qq.maps.LatLng(event.data.data.latLng.lat, event.data.data.latLng.lng), map: map }); const reverseGeocoder = new qq.maps.Geocoder({ complete: result => { if (result.detail.addressComponents) { const address = result.detail.addressComponents; const location = { city: address.city, district: address.district, street: address.street, latLng: event.data.data.latLng }; window.parent.postMessage({ type: "location", data: location }, "*"); } } }); reverseGeocoder.getAddress(new qq.maps.LatLng(event.data.data.latLng.lat, event.data.data.latLng.lng)); qq.maps.event.addListener(marker, "click", event => { const location = { city: marker.city, district: marker.district, street: marker.street, latLng: event.latLng }; window.parent.postMessage({ type: "location", data: location }, "*"); }); } }); </script> ``` 4. 在Vue组件的代码中,监听窗口的message事件,并根据接收到的消息类型进行处理。当收到location类型的消息时,获取选中的地点信息,并进行后续处理。 ``` <script> export default { mounted() { const iframe = document.getElementById("map-iframe"); iframe.addEventListener("load", () => { const message = { type: "show", data: { latLng: { lat: 39.916527, lng: 116.397128 } } }; iframe.contentWindow.postMessage(message, "*"); }); window.addEventListener("message", event => { if (event.origin !== "https://apis.map.qq.com") { return; } if (event.data.type === "location") { const location = event.data.data; console.log(location); } }); } }; </script> ``` 通过以上步骤,就可以在Vue中通过iframe调用腾讯地图地图选点组件,并实现反显地点的功能了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值