为移动设备开发web页面或者web应用与为桌面浏览器开发web页面不同,会出现很多新的挑战。为了帮助你开始,下面是一系列你需要遵循的最佳实践,以便为Android和其他移动设备提供最有效的web应用。
- 1. 将来自移动设备的请求重定向到专门为移动端设计的Web版本
有 好几种方式可以让你使用服务端的重定向将请求重定向到你的web站点的移动版本上去。最常见的情况是通过“嗅探”("sniffing")web浏览器提 供的用户代理字符串(User Agent string)。为了确定是否要提供一个你的站点的移动版本,你只需要在User Agent中寻找“mobile”字符串即可,它可以与很多移动设备匹配。如果需要的话,你还可以在用户代理字符串中找到特定的操作系统(比如 Android 2.1)。
注意: 大屏幕的Android设备需 要全尺寸的网站(比如平板电脑),因此在user agent中不包含“mobile”字符串,但它的user agent的其他部分基本是一样的。由于这种情况的存在,你在发送你的站点的移动端页面的时候,一定要确认user agent中是否包含“string”字符串。
- 2. 使用合适于移动设备的有效的 DOCTYPE 标记
为移动站点设计的最常见的标记语言是 XHTML Basic 。这一标准确保了特定的标记可以在移动设备上有最佳表现。例如,它不支持HTML框架或是嵌套表格,因为这些在移动设备上表现都很糟。除了声明DOCTYPE,还要声明合适的字符编码(比如UTF-8)。
例如:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.1//EN"
"http://www.w3.org/TR/xhtml-basic/xhtml-basic11.dtd">
一定要确认你的web页面的标记对于已经声明的DOCTYPE来说是有效的。可以使用验证器(validator),比如由http://validator.w3.org 提供的一个。
- 3. 使用 viewport 元数据来将页面调整至合适大小
在 你的文档的<head>部分,你需要提供元数据来指定你希望如何在浏览器的viewport中呈现你的页面。例如,你的viewport的元 数据可以指定浏览器的viewport的高和宽,最初的web页面规模甚至是目标屏幕分辨率(target screen density)。
例如:
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
想要获取更多关于如何为Android设备使用viewport元数据的信息,请阅读Targeting Screens from Web Apps 。
- 4. 避免多文件请求
因 为移动设备通常比台式机的联网速度慢得多,因此你需要想办法让你的页面尽快加载。一种加速加载方法是避免下载额外文件,比如<head>中的 样式表和脚本文件。相反,直接在<head>部分提供CSS或者Javascript即可(如果脚本是在页面加载完以后才用到,那么将其包含 在<body>的结束部分也可)。同样,你还可以通过类似于Minify 的工具来压缩你的文件。
- 5. 使用一个垂直的线性布局( Use a vertical linear layout )
在导航页面的时候,要避免让用户左右拖动你的页面。对于用户来说,上下拖动更容易,也让你的页面更简单。
要想知道更多关于如何创建伟大的移动web应用,请看W3C的移动设备最佳实践 。要看其他提升站点速度的建议(移动设备和桌面设备都适用),请看Yahoo!的最佳性能 指南以及Google在让web 更快 的加速教程。
原文链接:Best Practices for Web App
发表评论
-
响应式Web设计资源整理
2012-03-02 22:50 845这篇文章是对以往发表在Smashing Magazine上关于 ... -
投身移动开发必须知道的20件事
2012-03-01 23:42 762移动开发需要具体的设计考虑。这个所指的范围非常广,可以从“ ... -
聘用NodeJS开发者的六个建议
2012-03-01 23:41 853假设你正想聘用一名Node ... -
[摘要]Vision Mobile发布2012跨平台开发工具报告 PhoneGap最受欢迎
2012-03-01 23:41 911国外知名调查分析机构V ... -
Facebook发力Mobile Web 推出支付和测试工具
2012-02-28 23:49 824Facebook入场了,在MWC大 ... -
【数据】《移动优先》作者:为什么移动如此重要?
2012-02-28 23:48 945三 年前,前雅虎用户体验总监Luke Wrobl ... -
重新审视Mobile Web
2012-02-28 23:48 704作者简介:Byron是一个 ... -
WebAppTrend周刊:Google Chrome工程师推出Web App开发指南
2012-02-26 00:52 1224从本周起,WebAppTrend将精选一周内(2月20日~2月 ... -
Google Web App开发指南第四章:构建优秀的Web Apps
2012-02-24 23:13 1282构建漂亮的应用 一个web app 的视觉设计不仅 ... -
零基础学习Sencha Touch(资料和教程集合)
2012-02-23 00:41 1289译者注:本篇文章为开发者提供了零基础使用Sencha To ... -
Google Web Apps开发指南之项目样例(上)
2012-02-23 00:41 938如果缺少项目案例部 ... -
如何一步一步制作出高品质Infographic?
2012-02-20 21:23 982译者注:Infographic就 ... -
海豚浏览器CTO刘铁锋:Mobile Web App发展现状及展望
2012-02-18 00:10 881在计算机的发展过程中 ... -
海豚浏览器CTO刘铁锋:Mobile Web App发展现状及展望
2012-02-18 00:09 0在计算机的发展过程中 ... -
新手必读:PhoneGap入门六大问题
2012-02-18 00:08 1033很多PhoneGap新手总是需要一些基础问题的解答,Ado ... -
Google Web App开发指南第一章:什么是Web Apps?
2012-02-18 00:07 930很多人向我问起学习HTML5技术的权威入门资料,我总是毫不 ... -
Lanyrd是如何应用HTML5创建出优秀的移动Web应用的
2012-02-15 00:28 653当很多人都在等待观望 ... -
Appcelerator收购Cocoafish,旨在为Titanium平台提供即时移动云服务
2012-02-15 00:17 919译者注:Appcelerator是 ... -
Android官方文档之Web Apps调试
2012-02-15 00:13 914概览 你可以使用控制台的Javascript方法调试你的w ... -
Android官方文档在WebView中构建Web Apps
2012-02-15 00:13 806概览 在你的Android应用布局中使用 WebView ...
相关推荐
总的来说,这个"Office Web Apps示例程序"为开发者提供了一个实践OWA集成的起点,通过学习和分析这个项目,我们可以掌握如何在自定义Web应用中集成Office文档处理功能,提升用户体验并扩展应用的功能范围。...
### Pro Android Web Apps:利用HTML5、CSS3与JavaScript开发 #### 一、书籍概述 《Pro Android Web Apps: Develop for Android Using HTML5, CSS3 & JavaScript》是一本旨在教授开发者如何利用HTML5、CSS3及...
标题为"基于Progressive Web Apps的兼职云服务系统",暗示着文档将围绕Progressive Web Apps(渐进式网络应用,简称PWA)技术来构建一个服务于兼职市场的云服务平台。文档的核心内容将涉及云服务系统、云技术以及PWA...
让我们将您的网站和Web应用程序转换为Android应用程序。此应用程序模板支持各种Web应用程序/网站(包括HTML,PHP,WordPress,Progressive Web Apps,HTML 5 Games,WiX,Jimdo,apprat.io,bubble,Webflow,...)...
让我们将您的网站和Web应用程序转换为Android应用程序。此应用程序模板支持各种Web应用程序/网站(包括HTML,PHP,WordPress,Progressive Web Apps,HTML 5 Games,WiX,Jimdo,apprat.io,bubble,Webflow,...)...
《QUE.Android.Apps.Marketing.Sep.2010.pdf》这份文档,作为压缩包中的唯一文件,很可能是对以上所有概念的详细解读,包括理论知识、实战技巧以及对2010年Android应用市场的深度洞察。对于想要了解早期移动应用营销...
- **最佳实践**:分享了一些行业内的最佳实践,帮助开发者避免常见的陷阱并提高开发效率。 #### 八、资源推荐 - **在线教程和文档**:推荐了一些权威的在线资源,供读者进一步学习和参考。 - **社区支持**:介绍了...
《Build iOS & Android mobile apps in record time.pdf》这份文档详细介绍了如何利用Flutter框架与AWS Amplify服务来实现这一目标。通过这两个工具的结合使用,开发者可以极大地提高开发效率,并构建出高质量的移动...
开发书籍].Pro.Android.Web.Apps.Develop.for.Android.using.HTML5,.CSS3.&.JavaScript.pdf [android.开发书籍].Beginning.Android.Games.pdf [android.开发书籍].Hello.Android.3rd.Edition.pdf [android.开发书籍]...
综上所述,这本书是一本非常有价值的资源,不仅覆盖了Firebase在Android开发中的应用,还可能包含了云原生应用开发的最佳实践和实战技巧。对于希望提升Android应用性能,以及希望利用云端服务扩展应用功能的开发者来...
- 在Android项目的`assets`文件夹下创建`apps`文件夹,再新建一个以`manifest.json`中的`id`命名的文件夹。 - 将HBuilder生成的资源文件夹`www`复制到上述创建的文件夹内。 7. **复制data文件夹**: - 复制`...
在深入探讨Android源代码目录分析之前,我们先要理解Android系统的整体架构。Android是一个开源的操作系统,主要由Linux内核、运行库层、应用程序框架层和应用程序层组成。每个层次都包含一系列组件和服务,共同构成...
#### 二、Web Apps与Native Apps对比 1. **Web Apps** - **定义**: Web Apps是通过浏览器运行的应用程序,它们通常使用HTML、CSS和JavaScript编写。 - **优势**: - 跨平台:可以在任何支持浏览器的设备上运行。 ...
Web应用程序,通常被称为Web Apps,是通过互联网浏览器运行的应用程序,它们无需在用户计算机上安装即可使用。这种技术使得Web应用程序具有广泛可访问性,因为只需一个网络连接和任何能够浏览网页的设备即可使用。...
##### Web Apps Versus Native Apps **Web Apps** - **定义**:Web应用程序是指可以在任何现代浏览器上运行的应用程序。 - **优点**: - 跨平台兼容性好,只需要编写一次代码即可在多种设备上运行。 - 更新方便...