最近自学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)出现白屏解决方案的更多相关文章

  1. 关于百度地图api测距显示NaN的解决方案

    因为随着百度地图的api的升级,测距的函数以及语句都发生的一定变化. 在调用api测距的时候通常我们使用的是语句map.getDistance(marker1,marker2); 但为什么这么简单的测 ...

  2. 记录开发基于百度地图API实现在地图上绘制轨迹并拾取轨迹对应经纬度的工具说明

    前言: 最近一直在做数据可视化方面的工作,其中平面可视化没什么难度,毕竟已经有很多成熟的可供使用的框架,比如百度的echart.js,highcharts.js等.还有就是3D可视化了,整体来说难度也 ...

  3. 百度地图 api 功能封装类 (ZMap.js) 本地搜索,范围查找实例 [源码下载]

    相关说明 1. 界面查看: 吐槽贴:百度地图 api 封装 的实用功能 [源码下载] 2. 功能说明: 百度地图整合功能分享修正版[ZMap.js] 实例源码! ZMap.js 本类方法功能大多使用 ...

  4. 【百度地图API】JS版本的常见问题

    1.请问如何将我的店铺标注在百度地图上?我是否可以做区域代理?在百度地图上标注是否免费? 答复: 这里只负责API的技术咨询,不解决任何地图标注问题.在百度地图上标注自己公司,即气泡标注业务.该业务已 ...

  5. 百度地图 api 功能封装类 (ZMap.js) 本地搜索,范围查找实例

    百度地图 api 功能封装类 (ZMap.js) 本地搜索,范围查找实例 相关说明 1. 界面查看: 吐槽贴:百度地图 api 封装 的实用功能 [源码下载] 2. 功能说明: 百度地图整合功能分享修 ...

  6. 百度地图api通过地址显示地图,白名单

    百度地图api通过地址显示地图,白名单 http://developer.baidu.com/map/jsdemo.htm#i7_1?qq-pf-to=pcqq.c2c---------------- ...

  7. js百度地图API创建弧线并修改弧线的弧度

    去百度API官网下载CurveLine.min.js,注意复制下来的Js前面的行号要删除. // 百度地图API功能 var map = new BMap.Map("container&qu ...

  8. JS调用百度地图API标记地点

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  9. 百度地图api窗口信息自定义

    百度地图加载完后,完全可以用dom方法操作,比较常用的就是点击mark的弹窗,利用jQuery可以很快的创建弹窗,需要注意的就是地图都是异步加载,所以绑定时间要用 jQuery 事件 - delega ...

随机推荐

  1. react-native init安装指定版本的react-native

    C:\Users\ZHONGZHENHUA\imooc_gp\index.js index.js /** @format */ import React,{ Component } from 'rea ...

  2. 145. Binary Tree Postorder Traversal (Stack, Tree)

    Given a binary tree, return the postorder traversal of its nodes' values. For example: Given binary ...

  3. 隐藏在default construct后面的是什么

    C++新手很容易陷入两个认识上的误区: 1.任何类如果不显示的定义一个构造函数那么编译器就会构造出一个默认构造函数. 2.默认构造函数负责类的所有数据成员的初始化,显然不是这样的. 为什么不是这样的, ...

  4. networkX用法整

    无向图,有向图,加权图等例子代码 [http://www.cnblogs.com/kaituorensheng/p/5423131.html#_label1] 数据分析学习笔记(三)-NetworkX ...

  5. 导入excel精华版

    //须引入 NPOI, NPOI.OOXML, NPOI.Openxml4Net, NPOI.OpenxmlFormats等程序集 自己去下载吧 NPOI组件很好用不可能下不到自己去吧,通常去百度网盘 ...

  6. Oracle RMAN-06023 和ORA-19693错误

    在将一个0级备份的数据库还原到其它机器上时,首先遇到了RMAN-06023然后遇到ORA-19693错误,错误发生的环境和内容大致如下: 数据库版本: SQL> select * from v$ ...

  7. DapperExtensions 使用教程

    最近搭建一个框架,使用dapper来做数据库访问,数据是sql server2012,支持多个数据库.事务.orm.ado.net原生操作方式,非常方便. 使用dapper的原因网上有很多文章说明,这 ...

  8. 【转载】Redis Sentinel服务配置

    转载地址:http://blog.csdn.net/vtopqx/article/details/49247285 redis官网文档:http://www.redis.cn/topics/senti ...

  9. maven-multiModule

    主pom的定义 packaging:pom modules的指定 dependencyManagement的指定 properties的指定 build或profile的设置 子module的创建 在 ...

  10. mvn -v提示Permission denied

    解决办法: 增加权限 chmod a+x  /usr/local/apache-maven-3.5.2/bin/mvn 解释: (a:所有用户  +:增加权限   x:执行权限)