阅读更多

8顶
2踩

互联网

转载新闻 HTML5的明天:局部有小雨

2012-12-12 15:21 by 副主编 WnouM 评论(4) 有5752人浏览
本文转载自王淮(微博)的博客,他是Facebook支付后台及反欺诈部门前技术经理,现为天使投资人。


原文内容如下:

HTML5是什么?为什么很多人如此关注它并押上公司的未来?但为什么Facebook弃HTML5转Objective C。HTML的明天,是晴还是雨,你该不该给它投怀送抱,该如何去判断?

我最近对HTML5产生兴趣,就做了一些粗浅的研究,并和硅谷的两位玩弄HTML5多年的大佬Luke Shepard(原Facebook移动平台研发经理)和Feng Qian(Facebook高级工程师,原Google Chrome的创始团队成员)电话交流,总结于此篇文章。这篇文章不是HTML5的启蒙贴,是对其在业界发展的一个观察和思考吧。

什么是HTML5?

HTML5,就像其名字所表示的,它是HTML的第五个版本。它将现在大家在各种浏览器之中所做的很多很炫的插件或者特殊调准都做到了标准之中。这样的好处在于,大家不需要对于特殊的浏览器做特殊的优化,也可以避免了很多由于插件标准不统一带来的困扰。

比如,我很惊讶的了解到,Adobe的Flash+PDF插件导致的浏览器崩溃,占到所有浏览器崩溃次数的一半以上

HTML5的出现和推广,将通过统一的标准大大改观这种混乱的局面。最最主要的原生支持(native support),是这几种:

  • draw on the fly (随意拖动部件)
  • native video support (原声的视频支持 – bye,flash)
  • geolocation (地址信息的获取)
  • offline access support (不在线的支持,支持local storage)
  • semantics with tags that makes SEO friendly (flash content is not indexable – SEO能理解的tags来帮助搜索引擎的加索引)
但对于HTML5标准实现的程度和节奏完全取决于不同浏览器的自主选择,它想咋的就咋的。html5readiness.com上的这张图很清楚的总结了不同浏览器对于不同功能的实现程度。


你该不该给HTML5投怀送抱?

回答这个问题,要分成两步:你在WEB端还是移动端?

1. 如果是Web端,100%保证晴天;如果是移动端,看下一条

对于Web端而言,HTML5将是一个完整的操作系统。它在不同的底层系统之上,借助于浏览器的实现,封装了统一标准的API允许开发的程序跨设备(PC or Mac or Smart Phone),跨平台 (Windows,MacOS,iOS,Android,whatsoever)的运行。

最大的好处,就是一处开发,多处使用。审核新版本的发布也不用看苹果爷爷的脸色。直接在服务器端推送新代码就好了。对于开发人员而言,这对效率的提高,有着致命的诱惑。像”你们是先开发Web,还是移动”之类的问题,将愉快的失去意义。

对于Web端的开发而言,你可以尽情的享受HTML5这种统一封装带来的好处,唯一要等待的就是浏览器对其支持的完善。但这种完善的到来,无疑是确定的。

而正是这种好处,让很多创业者如此关注它并押上公司的未来。

但对于移动端而言,却没有那么简单纯粹。

2. 如果是移动端,取决于你的产品形态。

因为你的产品需要的功能可能永远也无法在移动端的浏览器的HTML5实现中被很好的实现。

App Store上超过50%的应用已经是用HTML5来开发,将来可能90%的应用会是HTML5,而那10%,可能永远也不适合HTML5。

HTML5的天气预报中,是局部有小雨。

苦逼的开发者们,你站的地是晴天还是下雨,该如何判断呢?

先介绍一个工具,动态检测浏览器对HTML支持程度的ringmark.io。如图所示,它将测试你当前的浏览器,将HTML5的规格(spec)当中描述的功能的实现程度会一一测试出来。不同的ring(环)代表了不同的功能等级。已经实现的为绿色,没实现的是灰色。发现灰色很多的朋友,要换浏览器啰。



回到刚开始的那个问题,Facebook为什么在iOS App的实现上弃HTML5选Object C,就在于Facebook App重度依赖照片,而照片分享,浏览相关的功能极度依赖CSS Overflow Scrolling,这一点,iOS上的浏览器支持极度不给力。而换成Object C的Native Implementation之后,速度快上了2倍之多。

好,有朋友可能会问,可能在将来浏览器对这些功能的支持会得到改善呢?那时候不就可以了。

事实是,那一天可能永远也不会到来。

因为浏览器的编程模型还是90年代流行的单进程单线程 (single process single thread),但原生实现(比如用Object C)的APP可以用多线程。这一点带来的作用是致命的。

移动端编写APP,可以使用多个线程,第一个线程,被称作主线程(main thread),编程的第一原则是don’t do heavy work on main thread。通常只让它处理UI事件等,其他重度的工作让其他背景线程来做。

但浏览器只有一个线程,所有的事情都是它干。浏览器编程一上来就破了第一原则。

在台式机上,浏览器编程还没有太多问题,因为够快;但在移动端,这个弊端很明显。

我来举个例子,比如你在用浏览器看朋友的照片,你发的评论被发到服务器端,此时你接着用手指往下拉屏;此时,服务器端返回信息,评论发布成功,浏览器中唯一的线程可能停止处理屏幕滚动(scrolling)而来处理服务器的返回信息,由于移动设备的处理器(尤其单进程浏览器只能用上单核,即使是多核手机!)和内存(处于省电原因使用低耗电的DDR1,这一点和现在PC使用的DDR3相差甚远)的不给力,完全可能造成滚动处理的不连续。通常手机的刷新率是60MHZ,即每一帧不超过15ms;如果处理的延时大大超过15ms,那么就会出现跳帧,肉眼就能看出来。

这是交互操作(比如拉动,滚动等)很多的APP,如果是由HTML5实现,出现拉动的时候停在那里一个很重要的原因。

所以,如果你的APP是相对静态的,不需要很多对于照片,多点触摸,多向拉动的处理,那完全可以用HTML5来实现;如果不是,比如信息流的展示,游戏等等,还是乖乖的用原生的去实现。

查看哪种类型的App需要哪些功能,可以进入ringmark.io,点开ring1,点击“See how features apply to each type of app.” 可以看到这个工具对于不同的App的类型做出的总结。比如,对于照片功能比较重的App(Camera App),你会发现他们需要什么样的功能,如果灰色(代表当前浏览器没实现)太多的话,你的App将不适合在这种浏览器中运行。

HTML5究竟在等什么?

HTML5实现已经是50%以上的iOS APP的选择。我相信处理能力的提升,将让移动设备的处理不给力带来的体验底下得到改善。而这种处理能力的提高,很大程度上将取决于低耗电高性能CPU/内存的出现,或者电池技术的极大改善。

在这一天到来之前,有可能10%的APP无法应用HTML5来实现。

一些用HTML5编写的好玩的网站

  • 大小: 38.6 KB
  • 大小: 52.6 KB
  • 大小: 13.4 KB
来自: 王淮的博客
8
2
评论 共 4 条 请登录后发表评论
4 楼 qq413041153 2012-12-13 13:00
我了解的html5怎么没这么强大?
3 楼 gandilong 2012-12-13 10:07
html5需要轻量化和通用化,更要有可靠的稳定性。
这只有这样,才能在其上谈更多的功能性。
2 楼 crazy24k 2012-12-13 09:54
引用
App Store上超过50%的应用已经是用HTML5来开发,将来可能90%的应用会是HTML5,而那10%,可能永远也不适合HTML5。

  真是扯淡,现在app store上不可能有50%的应用是用html5写的,然道你不知道很多html5应用是通不过苹果审核的么?
1 楼 sailei1 2012-12-13 09:36
  确实是这样!

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • Wininet编程 学习资料

    这是我学习Wininet编程时搜集的资料以及代码,感觉挺有用,故分享之

  • 使用WinInet类的学习体会

    下列代码摘录示范了如何创建一个简单的浏览器、下载一张网页、通过FTP操作一个文件和查找一个Gopher文件。它们并不是一个完整的例子,其中不包含异常处理,只是本人最近写程序的一点总结而已。1 创建一个非常简单的浏览器#include //假设URL的名字已经被初始化了CInternetSession session("My Session");CStdioFile* pFile=NULL;//

  • Wininet CInternetSession类编程的一些心得 包括如何清空cookie

    <br /> 废话不多直接说自己的心得了:<br /> <br />1、如何自己创建http头部:<br />先抓包自己登陆的网站封确定下封包头是什么样子的<br />然后构造<br />以下网址链接都是举例用的,实际网址及链 需要自己用抓包工具确定!<br />CString UrlHeadStr=_T("Accept: */*/r/nReferer: http://www.sina.com.com/r/nAccept-Language: zh-tw/r/nAccept-Encoding: gzip, d

  • 网络编程--WININET

    一个Internet客户端程序的目的是通过Internet协议如:HTTP、FTP等来存取网络数据源(服务器)的信息。客户端程序可以访问服务器获得象天气预报,股票价格、重要新闻数据,甚至是与服务器交换信息。Internet客户端程序可以通过外部网络(Internet)或内部网络(一般为Intranet)访问服务器。     为了开发Internet客户端程序。MFC类库提供了专门的 Win32 I

  • MFC WinInet类实现FTP客户端功能

    MFC WinInet类实现FTP客户端功能MFC WinInet类实现FTP客户端功能MFC WinInet类实现FTP客户端功能MFC WinInet类实现FTP客户端功能MFC WinInet类实现FTP客户端功能

  • WinInet学习资料

    我自己收藏整理的一点资料,那出来和大家分享,希望对大家有用。

  • WinInet类的介绍

            目前Visual C++ 6.0支持的网络编程有三种方式:一种是ISAPI,既基于网络服务器应用程序设计接口的程序,主要用来创建FTP服务器、PROXY代理服务器、HTTP服务器、SMTP服务器、BBS服务器、网络数据库服务器等服务器程序。一种是Windows Socket2,即基于Windows套接口编程,源于UNIX的套接口编程。还有一种便是WinInet基于国

  • WinInet编程详解

    一般而言,开发Internet服务客户端程序的目的是通过Internet协议(HTTP,FTP)获取网络数据源的信息,微软提供了专门的Win32 Internet扩展接口,也就是WinInet。 1使用Win API函数开发客户端程序 一般流程是,首先通过InternetOp

  • WinInet学习笔记(一)WinInet简介

    因为工作关系最近有用到WinInet,所以查阅了一些资料,第一篇只是简单的介绍介绍WinInet,后续的文章中会不断给出实例。 WinInet(「Windows Internet」)API帮助程序员使用三个常见的Internet协议,这三个协议是:用于World Wide Web万维网的超文本传输协议(HTTP:Hypertext Transfer Protocol)、文件传输协议(FTP:Fi...

  • WinInet使用详解

    WinInet是windows平台对socket进行一层封装,用来直接处理http/ftp/Gopher协议的一套windows API。我第一次接触这个是在一个客户那里,当时因为客户都需要使用http代理才能浏览网页,所以折腾了一天,才基本掌握。而时隔没多久又忘记的差不多了,这个流程就像正则表达式一样,常学常忘,常忘常学。而网络上流传的WinInet代码实例,不是编译不通过,就是粗制滥造。因此现

  • 【MFC】WinInet类的简单应用

    本例使用CWinInet类发送一HTTP请求,获取并显示相应的HTTP响应。 创建一个基于对话框的项目,添加两个文本框和两个按钮,如下图所示。 发送请求按钮的单击消息的消息处理函数如下所示。 void CDemoDlg::OnSendRequest() { const MAXBUF = 4096; CInternetSession session; CH

  • MSDN:使用 MFC WinInet 类编写 Internet 客户端应用程序

    使用 MFC WinInet 类编写 Internet 客户端应用程序 Visual Studio .NET 2003 每一个 Internet 客户端应用程序的基础都是 Internet 会话。MFC 将 Internet 会话作为 CInternetSession 类的对象来实现。使用此类可以创建一个 Internet 会话或几个同时进行的会话。 若要与服

  • wininet编程,下载者程序,包括获取文件大小

    看了一下wininet编程,底层实现其实封装了socket套接字,连接到服务器端口80,填充TCP数据部分作为HTTP协议的报头,然后SEND出去,等待recv的数据。          直接上代码吧            // 文件下载 CONSOLE.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include #includ

  • CInternetSession的使用

    CInternetSession的使用1. CInternetSession的简单使用CInternetSession session;CHttpFile *file = NULL; CString strURL = " http://www.20abcd.com";CString strHtml = "”;   //存放网页数据 try{       file =

  • WinInet和FTP

    WinInet和FTP(1)WinInet接口(含HTTP、FTP)及FTP函数层次关系 (2)Ftp函数介绍  ①InternetOpen——初始化,它告诉 Internet DLL 初始化内部数据结构并准备接收应用程序之后的其他调用。参数含义LPCTSTR lpszAgent调用WinInet函数的应用程序名字,在HTTP协议中作为用户代理项DWORD   dwAccessType访问要求类型...

Global site tag (gtag.js) - Google Analytics