WEB兼容性测试----移动端兼容矩阵的设计

屋顶的秘密

上期文章分享了PC端的web兼容测试,本期我们通过调研移动端web的特性和移动端浏览器特性,进一步探讨Web移动端的兼容测试。

  1. 移动端web的载体

同PC端一样,移动端的兼容性测试也是以浏览器为主。那么移动端的浏览器如何选取呢? 首先,我们把移动端web分为两类:纯网页形式、Hybrid App 内的web(常见的微信公众号内的H5页面即可以看作是此类网页)。此分类的依据是根据移动端web的载体形式,从本质上来看,网页的载体都是浏览器。随着技术的发展,浏览器以不同的形式出现,在移动设备中常见的有OS系统的Webview组件、第三方封装的Webview SDK、厂商的浏览器及第三方浏览器。下述表格体现了移动端web形式一般调用的载体形式(注:这仅表示常用形式,原生app内的也可以调用本机浏览器实现web展示,这里不做深入探讨)。


web形式分类

移动端浏览器有一个共性,底层都是基于Webkit内核开发的。根据上述的两类web形式,我们来具体看看载体的差异性。

1.1 Hybrid App载体

Hybrid App(混合模式移动应用)是指介于web-app、native-app这两者之间的app,兼具“Native App良好用户交互体验的优势”和“Web App跨平台开发的优势”(引自百度百科)。Hybrid App是运行在移动操作系统的WebView上面的,WebView实际上是一种嵌入式的编程接口,WebView调用底层的浏览器内核如WebKit等解析网页。从广义上看,Webview指操作系统提供的原生浏览器接口,从狭义上看,Webview特指android提供的原生浏览器接口。Android 4.4之前的Android系统浏览器内核是WebKit,Android4.4系统浏览器切换到了Chromium,内核是Webkit的分支Blink。Android基于chromium的webview相较于基于webkit的webview,提供更广的HTML5,CSS3,Javascript支持。在Android5.0以上的版本,支持了WebAudio,WebGL,WebRTC等更多的特性。
与之对应,ios提供的原生浏览器接口叫UIWebview,ios8以后变更为WKWebView。WKWebView引入了webkit内核,其优势表现在:更多的支持HTML5的特性;Safari相同的JavaScript引擎;;将UIWebViewDelegate与UIWebView拆分成了14类与3个协议(官方文档说明);增加加载进度属性:estimatedProgress等。
此外,针对andriod系统,许多第三方公司还提供了封装的浏览器服务来弥补android自带的webview组件的版本兼容问题,如:intel的crosswalk和腾讯的TBS服务(及QQ X5服务)。它们都是基于Chromium内核开发,但对andriod版本兼容问题作了更多的优化。


hybrid APP Web载体

基于第三方的webview组件,特别要提的是微信使用的TBS组件(微信的市场占有率高,小编的项目组较多使用了H5嵌入微信公众号)版本差异。微信6.1安卓版本开始使用的TBS服务内核是QQ浏览器X5内核,基于Android 5.0 WebView Blink内核(Chrome 37)开发的。但并非所有的机型都能支持调起微信浏览器内核服务(检测办法:1.使用微信打开网页,下拉查看显示;2. 查看UA),部分仍然使用的是android系统原生的webview,因为需要关注主流机型的差异性。相比而言,Ios版本的微信就直接多了,直接调用系统的webview(即UIWebwiew或WKWebview),跟随系统版本的升级,webview版本也不同。

1.2 纯网页载体

纯网页载体即为移动端浏览器。无论是各大手机厂商还提供自己封装的浏览器。这些浏览器,还是市场上流行的手机浏览器,底层技术都与webkit分不开关系。结合市场的占有率,移动端纯web的载体兼容应该着眼于主流浏览器。在android平台上,QQ手机浏览器和UC手机浏览器采用了基于webkit二次开发的内核,命名分别为X5以及U3,360手机浏览器和百度手机浏览器内核版采用的则是基于Chromuim内核二次开发的内核。而在iOS平台上,由于系统封闭,不允许除系统自带浏览器内核以外的浏览器内核进入,因此各家浏览器的开发均为在Safari的基础上进行二次开发,优化功能和自制UI。因此,关于移动端浏览器的兼容性问题,我们主要聚焦android平台。


引用艾媒北极星

值得一提的是,此类型兼容性测试过程中,除了UI和一般性交互的校验外,还应该关注浏览器的附属功能引发的异常,例如无痕浏览模式对缓存页面的影响、广告拦截模式对广告位的影响等。

2.移动设备的市场

软件和运行的系统是紧密联系的,关注系统、机型等的市场占有率能更有效的规划兼容性测试的范围。下面四幅图表示了💍2017年8月,市场上android和ios的系统版本占比,及对应的厂商机型。通过结合市场流行度和上述两类移动端web载体特性的分析,可以得出系统和平台兼容的列表(见小结)。


android系统版本国内市场占有率

android手机厂商国内市场占有率

ios系统版本国内市场占有率

iphone型号国内市场占有率

数据来源:百度浏览统计研究院

3.移动端设备的分辨率

  1. 移动端设备的分辨率
    在选择分辨率前,先了解几个概念:
    px(Pixels):像素,电子屏幕上组成一幅图画或照片的最基本单元,我们常说的屏幕分辨率的单位。
    ppi=dpi(Pixels Per Inch):每英寸像素数,即像素密度。该值越高,则屏幕越细腻。ppi= 屏幕对角线上的像素点数/对角线长度 = √ (屏幕横向像素点^2 + 屏幕纵向像素点^2)/屏幕尺寸。以三星note5为例,该屏幕分辨率为1440px2560px,5.7英寸。则点密度为 √ (1440^2 +2560^2) /5.7 = 515ppi。
    dpr(devicePixelRatio):设备像素比。是默认缩放为100%的情况下,设备上物理像素和设备独立像素比值。dpr=物理像素/css像素 (在x方向或者y方向)。javascript属性window.devicePixelRatio可以查看设备的dpr(http://www.zhangxinxu.com/study/201208/window-device-pixel-ratio.html)。例如iphone6使用的retina屏幕的设备像素比是2,其物理像素为1334
    750px,css的像素为667*375px。
    android的开发分辨率适配设计中还引入一个概念:dp = dip (device independent pixels):设备独立像素。1dp=(屏幕ppi/ 160)px。参考密度为160ppi,根据像素密度大致分为以下几种规格:
    android像素密度设计规格

    这些屏幕的密度值比为:ldpi : mdpi : hdpi : xhdpi : xxhdpi = 0.75 : 1 : 1.5 : 2 : 3;即,在xhdpi的密度下,1dp=2px;在hdpi情况下,1dp=1.5px。其他类推。开发过程中是基于devicePixelRatio=1的时候设计的,但UI资源区分@1x、@2x和@3x来适配不同设备像素比的屏幕。
    ios的从iphone4开始使用retina屏幕,改变了dpr:
    iphone屏幕密度分类

    通过上述的概念描述,移动端的分辨率不仅要关注物理像素本身,还应该屏幕密度来衡量分辨率的适配程度。网址(http://screensiz.es/phonehttp://dpi.lv/)可以快速查询到设备的屏幕和尺寸。结合市场目前流行的分辨率和厂商,可以得出目前分辨率兼容需要覆盖的范围(见小结)。
    android移动设备分辨率排名

    ios移动设备分辨率排名

4.小结

本文通过分析移动端web的两类形式:hybrid app和纯网页,调研了了市场关于系统、设备、分辨率的流行度,结合移动设备分辨率的特性,得出web移动端的兼容测试矩阵(目前移动端以html5技术为主,兼容列表适用于H5开发的移动端web)。


hybrid APP web页面平台及系统兼容矩阵

纯网页平台及系统兼容矩阵

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

推荐阅读更多精彩内容

  • 前言 Web的载体是浏览器,随着互联网的发展,市面上存在各式各样的浏览器,Web的兼容测试变得更加重要。然而,兼容...
    EchoDing阅读 4,219评论 0 5
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,728评论 1 92
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,514评论 25 707
  • 日精进打卡 姓名 朱均 企业名称 宁波大发化纤公司 组别 上海盛和塾276期反省一组 【日精进打卡第65天】 【知...
    朱均f7c8阅读 93评论 0 0
  • 相比较四年前的成都之行,此番行程依然匆忙。只是经历沧桑岁月,在诸多繁杂背后有更多惆怅,也更有一份宁静,毕竟这个世界...
    芈泽庆阅读 211评论 0 0