Ionic2使用百度地图API(JS)出现白屏解决方案
最近自学ionic2,写了一个内嵌百度地图JS的demo,实际跑起来之后出现了大家常见的白屏问题。。
最初的实现是这样的:
首先主页内嵌了一个百度地图插件
<div id="Bmap" style="width: 100%;height: 100%">
之后menu中一个引导的子页面也内嵌了一个百度地图
<div id="Bmap" style="width: 100%;height: 100%">
然后ionic serve编译执行,主页面显示正常,而子页面弹出时白屏。。
因为ionic2的本质是一个基于angular2的单页App,因此初步考虑是由于两个页面的地图层id都是Bmap冲突所致。
因此修改子页面百度地图层id
<div id="Smap" style="width: 100%;height: 100%">
再次执行,出现了常见的“第二次加载地图显示不全”的问题。
上网查证,原因是由于百度地图加载时其所在div隐藏或者使用了动画尚未完全显示的关系,解决方案为延迟200毫秒加载:
setTimeout(function(){that.initMap();},200);
执行,这次主页面和子页面的地图都能显示正常了。。
再次改造demo,子页面为一个list,list中每个元素对应一段独立的地图数据,复用地图子页面显示
itemTapped(event, item) { this.navCtrl.push(JourneyDetailsPage, {
item: item
}); }
点击跳转到地图子页面。
这次出现的问题为:主页面正常显示,子页面第一次正常显示,之后白屏。。
分析之后得出结论:因为使用同一个子页面,导致子页面间的地图层id冲突。
修改地图子页面:
<div id="Smap{{index}}" style="width: 100%; height: 100%"></div>
this.index = this.navParams.get('item')["index"];
index使用从列表传过来的参数做区分,这样以来虽然子页面相同,但每个子页面都将使用不同的地图层id,Smap1、Smap2.。。
创建百度地图代码:
this.map = new BMap.Map("Smap"+this.index.toString());
再次执行,问题彻底解决。
由此可总结出两点内容:
1. Ionic2是基于Angular2的单页应用(特殊需求的除外)
2. Ionic2使用navCtrl或者menu跳转到后一个新页面时,当前页面的上一个页面其实并未完全释放(可能是为页面回退做的优化处理)
出于这两点,使用Ionic2构建应用时,需特别注意不同组件间dom元素的id冲突问题。
以上。。
Ionic2使用百度地图API(JS)出现白屏解决方案的更多相关文章
- 关于百度地图api测距显示NaN的解决方案
因为随着百度地图的api的升级,测距的函数以及语句都发生的一定变化. 在调用api测距的时候通常我们使用的是语句map.getDistance(marker1,marker2); 但为什么这么简单的测 ...
- 记录开发基于百度地图API实现在地图上绘制轨迹并拾取轨迹对应经纬度的工具说明
前言: 最近一直在做数据可视化方面的工作,其中平面可视化没什么难度,毕竟已经有很多成熟的可供使用的框架,比如百度的echart.js,highcharts.js等.还有就是3D可视化了,整体来说难度也 ...
- 百度地图 api 功能封装类 (ZMap.js) 本地搜索,范围查找实例 [源码下载]
相关说明 1. 界面查看: 吐槽贴:百度地图 api 封装 的实用功能 [源码下载] 2. 功能说明: 百度地图整合功能分享修正版[ZMap.js] 实例源码! ZMap.js 本类方法功能大多使用 ...
- 【百度地图API】JS版本的常见问题
1.请问如何将我的店铺标注在百度地图上?我是否可以做区域代理?在百度地图上标注是否免费? 答复: 这里只负责API的技术咨询,不解决任何地图标注问题.在百度地图上标注自己公司,即气泡标注业务.该业务已 ...
- 百度地图 api 功能封装类 (ZMap.js) 本地搜索,范围查找实例
百度地图 api 功能封装类 (ZMap.js) 本地搜索,范围查找实例 相关说明 1. 界面查看: 吐槽贴:百度地图 api 封装 的实用功能 [源码下载] 2. 功能说明: 百度地图整合功能分享修 ...
- 百度地图api通过地址显示地图,白名单
百度地图api通过地址显示地图,白名单 http://developer.baidu.com/map/jsdemo.htm#i7_1?qq-pf-to=pcqq.c2c---------------- ...
- js百度地图API创建弧线并修改弧线的弧度
去百度API官网下载CurveLine.min.js,注意复制下来的Js前面的行号要删除. // 百度地图API功能 var map = new BMap.Map("container&qu ...
- JS调用百度地图API标记地点
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...
- 百度地图api窗口信息自定义
百度地图加载完后,完全可以用dom方法操作,比较常用的就是点击mark的弹窗,利用jQuery可以很快的创建弹窗,需要注意的就是地图都是异步加载,所以绑定时间要用 jQuery 事件 - delega ...
随机推荐
- 【BZOJ 2120】数颜色【分块/莫队】
题意 给出n个数字和m个操作.操作有两种.1:查询区间[l,r]内不同种类得数字个数.2: 将下标为p得数字修改为v 分析 如果不是修改操作的话,用莫队贼简单就可以水过,但是因为带了修改就有一些麻烦了 ...
- Spring学习笔记(四)--MVC概述
一. 飞机 最近马来西亚航空370号班机事故闹得沸沸扬扬,情节整的扑朔迷离,连我在钻研springMVC平和的心情都间接的受到了影响.正当我在想这个MVC的处理过程可以怎样得到更好的理解呢?灰机,灰机 ...
- Hibernate入门级实例
一.开发环境 Win8 + jdk1.7 + MyEclipse + Tomcat5.0 + MySQL 说明:其实Hibernate是非常独立的框架,根本不需要MyEclipse,Eclipse,T ...
- sqlserver 时间函数用法
1.DATEADD(datepart,number,date) 现在,我们希望向 "OrderDate" 添加 2 天,这样就可以找到付款日期,我们使用如下 SELECT 语句: ...
- maven filter插件只替换了部分变量问题
maven filter简介 maven的resources插件,有一个filter的作用,能够在打包的时候,从特定文件里读取key-value对,替换配置文件中的占位符变量.很多线上线下有不同环境的 ...
- scrapy框架 小知识
持久化 去重规则 深度 cookie start_url 深度和优先级 下载中间件 持久化 步骤 pipeline/items a. 先写pipeline类 class XXXPipeline(obj ...
- Texstudio
Texstudio快捷键:Ctrl+T,选中之后按这个可以快速注释
- Spring AOP 详解 【转】
此前对于AOP的使用仅限于声明式事务,除此之外在实际开发中也没有遇到过与之相关的问题.最近项目中遇到了以下几点需求,仔细思考之后,觉得采用AOP 来解决.一方面是为了以更加灵活的方式来解决问题,另 ...
- 支持stl容器的gdb自定义命令
# 本文可以从https://sourceware.org/ml/gdb/2008-02/msg00064/stl-views.gdb直接下载 # 有关gdb的高级使用,请浏览:http://blog ...
- SQL server 累加求和
1. SELECT SalesOrderID, ProductID, OrderQty ,SUM(OrderQty) OVER(PARTITION BY SalesOrderID) AS Tot ...