-webkit-overflow-scrolling: touch导致Native滚动时出现黑色背景

CSS3 的 -webkit-overflow-scrolling: touch 可以让页面在Native端滚动时模拟原生的弹性滚动效果。

项目开发中用到该属性,但导致Native端在弹性滚动到边界时出现一个黑色背景的VIEW。

查了一下网上的资料,H5端代码就不再敷述了,看一下Native处理

-webkit-overflow-scrolling: touch 的流程如下:

实际上,Safari真的用了原生控件来实现,对于有-webkit-overflow-scrolling的网页,会创建一个UIScrollView,提供子layer给渲染模块使用。创建时的堆栈如下:

Thread 1, Queue : com.apple.main-thread

#0  0x00086723 in -[UIScrollView initWithFrame:] ()

#1  0x004ec3bd in -[UIWebOverflowScrollView initWithLayer:node:webDocumentView:] ()

#2  0x001f1769 in -[UIWebDocumentView webView:didCreateOrUpdateScrollingLayer:

   withContentsLayer:scrollSize:forNode:allowHorizontalScrollbar:allowVerticalScrollbar:] ()

#3  0x01d571bd in __invoking___ ()

#4  0x01d570d6 in -[NSInvocation invoke] ()

#5  0x01d5724a in -[NSInvocation invokeWithTarget:] ()

#6  0x027fb6a1 in -[_WebSafeForwarder forwardInvocation:] ()

#7  0x027fb8ab in __44-[_WebSafeAsyncForwarder forwardInvocation:]_block_invoke_0 ()

#8  0x04ac753f in _dispatch_call_block_and_release ()

#9  0x04ad9014 in _dispatch_client_callout ()

#10 0x04ac97d5 in _dispatch_main_queue_callback_4CF ()

#11 0x01d09af5 in __CFRunLoopRun ()

#12 0x01d08f44 in CFRunLoopRunSpecific ()

#13 0x01d08e1b in CFRunLoopRunInMode ()

#14 0x01cbd7e3 in GSEventRunModal ()

#15 0x01cbd668 in GSEventRun ()

#16 0x00032ffc in UIApplicationMain ()

#17 0x00002ae2 in main at /Users/liuhx/Desktop/UIWebView_Research/WebViewResearch/main.mm:16

实际创建的是UIWebOverflowScrollView,它继承自UIScrollView,声明为:

@class DOMNode, UIWebDocumentView, UIWebOverflowContentView, UIWebOverflowScrollListener;

@interface UIWebOverflowScrollView : UIScrollView

{

        UIWebDocumentView *_webDocumentView;

        UIWebOverflowScrollListener *_scrollListener;

        UIWebOverflowContentView *_overflowContentView;

        DOMNode *_node;

        BOOL _beingRemoved;

}

@property(nonatomic, getter=isBeingRemoved) BOOL beingRemoved; // @synthesize beingRemoved=_beingRemoved;

@property(retain, nonatomic) DOMNode *node; // @synthesize node=_node;

@property(retain, nonatomic) UIWebOverflowContentView *overflowContentView; // @synthesize overflowContentView=_overflowContentView;

@property(retain, nonatomic) UIWebOverflowScrollListener *scrollListener; // @synthesize scrollListener=_scrollListener;

@property(nonatomic) UIWebDocumentView *webDocumentView; // @synthesize webDocumentView=_webDocumentView;

- (void)setContentOffset:(struct CGPoint)arg1;

- (void)_replaceLayer:(id)arg1;

- (void)prepareForRemoval;

- (void)fixUpViewAfterInsertion;

- (id)superview;

- (void)dealloc;

- (id)initWithLayer:(id)arg1 node:(id)arg2 webDocumentView:(id)arg3;

@end

其还有一个子View作为ContentView,是给WebCore真正用作渲染overflow型内容的layer的容器。

UIWebOverflowContentView的声明为:


@interface UIWebOverflowContentView : UIView

{

}

- (void)_setCachedSubviews:(id)arg1;

- (void)_replaceLayer:(id)arg1;

- (void)fixUpViewAfterInsertion;

- (id)superview;

- (id)initWithLayer:(id)arg1;

@end

再往底层跟,都是CALayer的操作。

以上两个类都是UIKit层的实现,需要WebCore有硬件加速的支持才有实际意义,相关的逻辑被包含在

ACCELERATED_COMPOSITING

这个宏里。

从SVN log看,在WebKit 108400版本左右才支持,所以iOS Safari应该是需要5.0。Android只在4.0以上支持。

从前端开发的角度讲,只需要知道CSS的属性-webkit-overflow-scrolling是真的创建了带有硬件加速的系统级控件,所以效率很高。但是这相对是耗更多内存的,最好在产生了非常大面积的overflow时才应用。


出现黑色背景View其实就是UIWebOverflowScrollView。这个UIWebOverflowScrollView只有当页面上产生滚动条的时候才会生成,也就是后加载,所以在模块运行之初去捕捉并设置这个VIEW是捕获不到且不起作用的。

处理思路:

在html端的JS中对滚动条进行监听判断,当页面出现滚动条时通知Native端。

本人在项目中使用 WebViewJavascriptBridge  建立H5端与Native端的桥接。Android版本的点这里

Native获取到页面出现滚动条的通知,再去捕获这个View并修改颜色为白色,当然颜色是按照你自己的设计来修改的,如果本身的APP为黑色,那不改也无妨。

代码如下:

if ([_aView isKindOfClass:[UIScrollView class]])

{

        _aView.backgroundColor = [UIColor whiteColor];

        //下侧的滚动条

        UIView *view = _aView.subviews[0];

        for (UIView *_inScrollview in view.subviews)

        {

                 NSLog(@"b—%@",_inScrollview);

                 _inScrollview.layer.backgroundColor = [UIColor whiteColor].CGColor;

        }

}

最后提一下,由于-webkit-overflow-scrolling: touch对内存消耗不小,通知Native的捕获事件尽量只做一次,节省开销。


资料来源:

网页在Safari快速滚动和回弹的原理: -webkit-overflow-scrolling : touch;的实现

marcuswestin/WebViewJavascriptBridge

jesse01/WebViewJavascriptBridge

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,974评论 25 707
  • 简介: 提供一个让有限的窗口变成一个大数据集的灵活视图。 术语表: Adapter:RecyclerView的子类...
    酷泡泡阅读 5,159评论 0 16
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,383评论 0 17
  • 青春是匹不羁的野马 午夜在山路上奔驰 月亮跟随着我疯狂 你是否也在注视 这一轮明月 告诉我 一定会在见 等待的容颜...
    燃烧吧情怀阅读 234评论 0 7
  • 无论生活如何暴击,她们也不放弃充盈自己,总是衣着得体,依旧热爱看书学习,时刻不放弃成为更好的自己。 很多事情别人没...
    大树是个小说迷阅读 186评论 0 1