一、问题产生:

在ionic app 优化方案中,我在前之前的博文中提到使用 --crosswalkwebview;

使用了crosswalkwebview后,app的显示及兼容效果确实很不错,虽然app大小多了20m左右,但是,当时想着,没所谓了,只要体验提升了即可;

但是在之后,我突然发现了一个bug:

“当ionic的键盘弹出的瞬间,整个视图会出现迷之闪动,貌似那一瞬间,整个视图被压缩得剩下一半了”

这个bug特别是在有背景图片的视图的情况下,显得特别的恶心,也就是整个背景图片在那一瞬间被无情的压缩,显得特别难看;

在网上各种搜索,并不能找到相应的解决方案,浑身难受~~~

二、思考:

后来自己在研究这个bug原因的时候,发现了,当app处于全屏的时候,这个bug就不复存在了;

这个发现让我突然想到了状态栏,statusBar,肯定和它有关系;

于是,我把状态栏设置为:

StatusBar.overlaysWebView(true),也就是悬浮状态;

在打包尝试的时候,确实,这个bug没有出现,因此这里,我想到了个解决方案,就是将状态栏设置成悬浮,然后,header 和 ion-content 都给个margin-top ,值为状态栏的高度;

三、解决

1、确定装了2个cordova插件

cordova plugin add cordova-plugin-statusbar

cordova plugin add ionic-plugin-keyboard

2、在入口页面 index.html ,为ion-nav-view 添加 id="adjustHeightAfterKeyboard"

3、在app.js里面添加一下代码

if (window.cordova && window.cordova.plugins && window.cordova.plugins.Keyboard) {
cordova.plugins.Keyboard.hideKeyboardAccessoryBar(true);
cordova.plugins.Keyboard.disableScroll(true);
//动态计算最外层 ion-nav-view 的高度,使键盘弹出时不会挡住内容
window.addEventListener('native.keyboardshow', keyboardShowHandler);
window.addEventListener('native.keyboardhide', keyboardHideHandler);
var viewDom = document.getElementById('adjustHeightAfterKeyboard')
function keyboardShowHandler(e){
var viewHight = document.body.clientHeight - e.keyboardHeight;
viewDom.style.height = viewHight + 'px';
}
function keyboardHideHandler(e){
viewDom.style.height = document.body.clientHeight + 'px';
}
} if (window.StatusBar) {
//将手机状态栏设置成悬浮
StatusBar.overlaysWebView(true);
StatusBar.backgroundColorByHexString("#2e2b36");
}

4、给header-bar 和ion-content 加上上边距

.bar-header{
box-shadow: 0 1px 1px 0 #eee;
margin-top:23px;
}
.scroll-content{
margin-top:23px;
}

ok,到此,假装以为可以了,运行了下,好像确实可以,但是,又出现了一个bug,心好累!!

app 在splashscreen 消失,进入首页的时候,状态栏并不悬浮,导致了明显的空白上边距,而其他页面都不会,且从其他页面再切回来首页的时候,bug就消失了。

因此,我只能又加了个判断,在首页的controller.js写上以下代码

//修复首次进来头部有margin 的bug;(判断历史的view个数并且判断其他视图是否被点击缓存着)
var childViews = Object.keys($ionicHistory.viewHistory().views).length; //视图里面历史view个数
var sblingsViews = $('.tab-content').length; //tab视图的个数
if(childViews == 1 && sblingsViews == 1){
$scope.isFirstTimeHome = true;
}else{
setTimeout(function(){
$scope.isFirstTimeHome = false;
},300)
}

 根据 $scope.isFirstTimeHome 来控制是否让margin-top 为0,也即是说如果是首次进来$scope.isFirstTimeHome =true,让margin-top为0,就解决了该bug

 

ok,到此为止,算是解决了;

但是我想着,是否有更好的方法能解决啊,好烦,ionic的bug真心难解决,重点是搜索不到和我这个问题类似的解决方案,一个都没有,目前只能这样解决;

如果有更好的建议的朋友希望能给我回复下,感谢!

ionic 使用了 crosswalkwebview 所产生的bug 及 解决方案的更多相关文章

  1. 移动Web开发的bug及解决方案

    我目前移动Web开发遇到的bug以及解决方案(慢慢补充当中). 1.android4.0以上一部分手机的webview中,当canvas小于屏幕大小时,绘图时会出现重影,就是说一个图只绘制了一遍,却出 ...

  2. MySQL中char(36)被认为是GUID导致的BUG及解决方案

    MySQL中char(36)被认为是GUID导致的BUG及解决方案 有时候在使用Toad或在程序中,偶尔会遇到如下的错误: System.FormatException GUID 应包含带 4 个短划 ...

  3. [转]rpcndr.h和wtypes.h冲突Bug的解决方案

    [转]rpcndr.h和wtypes.h冲突Bug的解决方案 http://blog.csdn.net/tzwh_86/article/details/9495133 rpcndr.h和wtypes. ...

  4. 转:移动开发中一些bug及解决方案

    网页开发要面对各种各样的浏览器,让人很头疼,而移动开发中,你不但要面对浏览器,还要面对各种版本的手机,iOS好一点,而安卓就五花八门了,你可能在开发中也被它们折磨过,或者正在被它们折磨,我在这里说几个 ...

  5. pycharm下: conda installation is not found ----一个公开的bug的解决方案

    pycharm  conda installation is not  found ----一个公开的bug的解决方案 pycharm+anaconda 是当前的主流的搭建方案,但是常出现上述问题. ...

  6. ionic 中$ionicView.beforeEnter 事件的一个bug

    我在使用ionic写app的时候,需要使用$IonicView.beforeEnter事件,在页面进入前做一些事情,但是发现,它不起作用,很蛋疼,后来,看了别人做的app例子,也涉及到这个$Ionic ...

  7. IOS9.0中hash值的bug与解决方案

    事件起因 事情是这样的:产品上线发布,突然出现了问题.运营Gg过来反应,当场给露珠演示,运营同事的手机是iphone,bug确实是存在的.奇怪的是露珠用了其他iphone手机(借别人的,露珠的是吊死安 ...

  8. 线上bug的解决方案--带来的全新架构设计

    缘由 本人从事游戏开发很多年一直都是游戏服务器端开发. 因为个人原因吧,一直在小型公司,或者叫创业型团队工作吧.这样的环境下不得不逼迫我需要什么都会,什么做. 但是自我感觉好像什么都不精通..... ...

  9. 常见bug及解决方案

    1.外边距叠加 一.发生在一个div内 <!DOCTYPE> <html> <head> <meta http-equiv=Content-Type cont ...

随机推荐

  1. 【算法系列学习】Dijkstra单源最短路 [kuangbin带你飞]专题四 最短路练习 A - Til the Cows Come Home

    https://vjudge.net/contest/66569#problem/A http://blog.csdn.net/wangjian8006/article/details/7871889 ...

  2. SQL中LEFT JOIN 和 inner join 的区别

    student表 sc 表 首先where条件a.Sid = b.Sid 查询 SELECT * FROM student a,sc b WHERE a.Sid = b.Sid GROUP BY a. ...

  3. EmpyoyeeManger_1.0

    整体结构 首先创建一个名为employee的数据库 create database employee; 然后在该数据库下建一张表 CREATE TABLE t_emp( id BIGINT PRIMA ...

  4. session与cookie-----2017-05-08

    会话控制:目的是记录不同用户身份. 1.session:有实效性 特点: (1)存在在服务器 (2)每个用户都会存一份 (3)可以存储任意类型的数据 优点:安全性高 缺点:服务器压力过大 2.cook ...

  5. IOS(二)基本控件UIButton、简易动画、transform属性、UIImageView

    UIButton //1.设置UIButton 的左右移动 .center属性 获得 CGPoint 来修改x y //1.设置UIButton 的放大缩小 bounds属性 获得CGRect 然后通 ...

  6. 记事本app TOP5(个人观点)

    1.为知笔记 为知笔记定位于高效率工作笔记,主打工作笔记的移动应用,是目前国内唯一一款"工作笔记"的云笔记类产品.除了常用的笔记功能保存的网页.灵感笔记.重要文档.照片.便签等,为 ...

  7. LNMP源码编译安装

    思路:根据Linux系统以及公司网站系统的信息,选择合适的安装包进行安装 一.查看系统信息 # uname -a                        # 查看内核/操作系统/CPU信息 # ...

  8. 添加Metasploit-payload到已有的Android项目中

    metasploit在写这篇文章之前,笔者可以说是对java一窍不通,也从来没有写过什么Android应用,在几天的摸爬滚打中终于实现了最终的目的,就是在已有Apk源码的情况下,用了比较另类的方式,添 ...

  9. python 基本数据类型set

    set 是一个无序且不重复的序列 set 是一个无序且不重复的序列 set 不允许重复的集合.set不允许重复的序列 1.创建 s=set() #创建空集合只能用这种方法 s={11,222,233, ...

  10. 字符串时间和NSDate相互转换的坑

    项目中服务器传回来的时间是这种格式的 Sep 5, 2016 6:59:05 PM 现在要将这段字符串转换成 2016-09-05 06:59 被坑的地方有2个点 服务器传回来的英文的Sep,调试的时 ...