打造移动终端的 WebApp(一):搭建一个舞台
最近随着 Apple iOS 和 Android 平台的盛行,一个新的名词 WebApp 也逐渐火了起来,这里我也趁着热潮做一个关于 WebApp 系列的学习笔记,分享平时的一些研究以及项目中的经验,在现阶段研究对象暂时限定为 iOS 平台(iPhone/iPad/iPod touch),随后会扩展到 Android 平台。
对于 WebApp,我的理解是:它一个基于 Web 形式的应用程序,是针对智能手机、平板电脑等高性能移动设备做了特别优化的网页或网站,它相对原生应用程序(Native App)优势在于:
- 我们可以使用熟悉的开发环境和开发工具,当然也包括熟悉的语言:HTML+CSS+Javascript
- 测试方便,大多数情况下一个浏览器就OK,推荐使用Safari 5,自带的开发功能中可以模拟iphone/ipad等设备的UA
- 开发速度快,维护简单,更新方便。
下面开始逐步学习、探讨如何打造一个适合移动终端的 WebApp。
一、准备工作:搭建一个舞台:
首先我们已经有一个性能不错的平台——基于 Webkit 内核的 Safari 浏览器(这里指的是 iOS 中的移动版 Safari,下同),但这还不够,虽说是移动版浏览器,但在未设置、优化前,Safari 对页面的渲染方式更多的是为方便浏览 PC 网页而优化,这就难以体现 WebApp 的特点,所以我们必须通过一些设置来搭建一个属于 WebApp 的“舞台”。
PS:下面列举的代码都应放置在 HTML 文档的<head>标签内。
1.设置 viewpoint:
当我们在 Safari 中打开一个网站时,默认情况下浏览器会对网页进行缩放显示,目的是让 PC 页面能够完全展示在小屏幕设备中,而这种缩放功能会严重影响专为移动设备屏幕尺寸设计的 WebApp 的体验,所以需要通过以下代码来关闭缩放:
<meta name = "viewport" content = "user-scalable=no, width=device-width">
设置viewpoint前后效果对比:

简单了解下viewpoint的属性:
user-scalable – 用户是否可以手动缩放;
width – 定义viewport宽度(默认为980像素) ,例子中值为device-width是指设置为设备显示宽度;
height – viewport的高度;
initial-scale – 初始的缩放比例 (范围从 0 到10);
minimum-scale – 允许用户缩放到的最小比例;
maximum-scale – 允许用户缩放到的最大比例;
有关viewpoint更详细的知识请移步:viewport不权威指南
2.设置主屏幕(Spring Board)启动图标:
Safari 浏览器有一个“添加到主屏幕”的功能,用户可以像保存书签一样把一个网站添加到主屏幕,下次用户直接点击主屏幕上的图标就能进入网站。

这个功能不仅方便用户快速访问我们的网站,而且也使我们的 WebApp 更像一个原生应用,设置代码:
<link rel="apple-touch-icon" href="icon.png" />
iOS 系统会自动将图标生成具有高光、圆角和阴影效果:

如果你不想要系统自动生成的效果,可以增加rel="apple-touch-icon-precomposed"属性:
<link rel="apple-touch-icon-precomposed" href="icon.png" />
因为 iOS 分辨率,所以 icon.png 图片的尺寸也各不相同,我们可以通过sizes属性来分别定义,iOS 系统会自动获取向匹配的图片:
<!--默认为 57x57 像素-->
<link rel="apple-touch-icon" href="touch-icon-iphone.png" />
<!--iPad 1 72x72 像素-->
<link rel="apple-touch-icon" sizes="72x72" href="touch-icon-ipad.png" />
<!--iPhone 4 114x114 像素-->
<link rel="apple-touch-icon" sizes="114x114" href="touch-icon-iphone4.png" />
系统会自动选取网站title,作为名称显示在主屏图标下方,最长显示13字符。

为了在主屏达到最好的显示效果,title最好限制在六个中文长度内,超长的内容会被隐藏:

3.全屏显示 WebApp,隐藏 safari 导航栏以及工具栏:
当我们点击主屏图标打开浏览器进入 WebApp 时,默认情况下 Safari 还是会显示顶部导航栏以及底部工具栏,但这不是我们想要的结果,它们不仅不美观还减少了显示面积,所以可以用以下代码隐藏它们,让 WebApp 像原生应用一样全屏显示:
<meta name="apple-mobile-web-app-capable" content="yes" />
iPad 中的全屏显示效果,导航和工具栏已经没有了:
注:想达到全屏显示的效果必须通过主屏的图标打开网站,直接在Safari输入URL是不行的。
4.设置系统状态栏风格:
系统状态栏是 iOS 顶部显示运营商、WIFI、时间的部分,它无法隐藏,但可以设置灰、黑两种风格,设置代码如下:
<meta name="apple-mobile-web-app-status-bar-style" content="grey" />
<meta name="apple-mobile-web-app-status-bar-style" content="black" />
5.启动画面设置:
当用户点击主屏图标打开 WebApp 时,系统会展示启动画面,在未设置情况下系统会默认显示该网站的首页截图,当然这个体验不是很好,所以我们需要通过以下代码来自定义启动画面:
<link rel="apple-touch-startup-image" href="Startup.png" />
[2012.11.20]更新
与启图标类似,根据 iOS 设备的分辨率,其启动画面的图片尺寸也各不相同:
iPhone 3GS(及以前机型):320×460 像素
iPhone 4、4S:640×920 像素
iPhone 5:1096×640 像素
iPad 1、2:768×1004 像素
New iPad:–
iPad mini —
注:如果图片尺寸不对将无法显示。
[2011.2.1]更新
如果想让一个 WebApp 在 iPhone 和 iPad 中同时具有启动画面,我们可以借助 Javascript 脚本来完成,通过判断设备navigator.userAgent信息,来更改href的值指向对应的图片路径:
//jQuery
var ua = navigator.userAgent.toLowerCase();
if (ua.match(/iPad/i)=="ipad") {
$("link[rel=apple-touch-startup-image]").attr("href","images/startup_ipad.png");
}
其他细节设置:
屏蔽iPhone下的拨号链接
iPhone 下会自动将连串数字转换为拨号超链接,如果没特别的需要还是将这个功能屏蔽为好:
<meta name="format-detection" content="telephone=no"/>
至此一个专属于 WebApp 的“舞台”就初步搭建完成了,当然这里也留下很多疑问,比如说iPhone与iPad分辨率差距很大,那么如何为它们分别设置启动画面、布局样式以及横屏竖屏的问题等,这些细节将在下一章讨论。
打造移动终端的 WebApp(一):搭建一个舞台的更多相关文章
- 如何用 Parse 和 Swift 搭建一个像 Instagram 那样的应用?
[编者按]本篇文章作者是Reinder de Vries,既是一名企业家,也是优秀的程序员,发表多篇应用程序的博客.本篇文章中,作者主要介绍了如何基于Parse特点,打造一款类似Instagram的应 ...
- Parse 和 Swift 搭建一个像 Instagram
如何用 Parse 和 Swift 搭建一个像 Instagram 那样的应用? [编者按]本篇文章作者是Reinder de Vries,既是一名企业家,也是优秀的程序员,发表多篇应用程序的博客 ...
- Vite+TS带你搭建一个属于自己的Vue3组件库
theme: nico 前言 随着前端技术的发展,业界涌现出了许多的UI组件库.例如我们熟知的ElementUI,Vant,AntDesign等等.但是作为一个前端开发者,你知道一个UI组件库是如何被 ...
- 基于hexo+github搭建一个独立博客
一直听说用hexo搭建一个拥有自己域名的博客是很酷炫的事情~,在这十一花上半个小时整个hexo博客岂不美哉. 使用Hexo吸引我的是,其简单优雅, 而且风格多变, 适合程序员搭建个人博客,而且支持多平 ...
- 搭建一个Web应用
因为EasyUI会涉及到与后台数据的交互,所以使用Spring MVC作为后台,搭建一个完整的Web环境 使用gradle作为构建工具 build.gradle group 'org.zln.lkd' ...
- Django1.8教程——从零开始搭建一个完整django博客(一)
第一个Django项目将是一个完整的博客网站.它和我们博客园使用的博客别无二致,一样有分类.标签.归档.查询等功能.如果你对Django感兴趣的话,这是一个绝好的机会.该教程将和你一起,从零开始,搭建 ...
- 搭建一个免费的,无限流量的Blog----github Pages和Jekyll入门
喜欢写Blog的人,会经历三个阶段. 第一阶段,刚接触Blog,觉得很新鲜,试着选择一个免费空间来写. 第二阶段,发现免费空间限制太多,就自己购买域名和空间,搭建独立博客. 第三阶段,觉得独立博客的管 ...
- 在Linux中搭建一个FTP服务器
在Linux中搭建一个ftp服务器,以供两个工作小组保管文件使用.禁用匿名.第一个小组使用ftp账号:ftp1,工作目录在:/var/ftp/ftp1:第二个小组使用ftp2,工作目录在:/var/f ...
- 如何用 Parse 和 Swift 搭建一个像 Instagram 那样的应用?(3)
[编者按]本篇文章作者是 Reinder de Vries,既是一名企业家,也是优秀的程序员,发表多篇应用程序的博客.本篇文章中,作者主要介绍了如何基于 Parse 特点,打造一款类似 Instagr ...
随机推荐
- js的一些小笔记,(不定期更新)
2个$的用法$本身并无特定意义,它表示什么意思要看是如何定义的,如果没有定义就便是两个$,可能是变量名的开始.一般是一个函数,用来代替document.getElementByIdfunction $ ...
- [工作bug]一个weblogic跨应用导致session丢失的bug之旅
近来,发布一个应用,开发和本地测试一切都好,一旦部署到测试环境之后,坑爹的问题随之而来,应用程序不定时的超时,导致用户正在操作过程中被踢了出来,纠结了几天,终于在今天将此问题搞定: 1.系统架构 系统 ...
- linux(centos6)搭建ftp服务器
前提 ssh服务已经开启,关闭防火墙,主机和虚拟机能ping通 查看ssh和防火墙的状态 service sshd status service iptables status 开启ssh服务 ser ...
- iOS 注意事项
1.记得在项目中设置项目文件命名的prefix,避免命名冲突. 2.在适当的位置对属性和方法进行注释,建议利用插件(如VVDocument)提供效率.在给企业看文档时,可以利用(如Doxygen)这种 ...
- 疯狂java学习笔记之面向对象(四) - this关键字
Java中this关键字主要有以下两个方法: 1.this引用 - 可用于任何非static修饰的方法和构造器中,当this用于方法中时,它代表调用该方法的实例/对象;当this用于构造器中时,它代表 ...
- details和summary
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- ai seek
原文地址链接:http://gamedevelopment.tutsplus.com/tutorials/understanding-steering-behaviors-seek--gamedev- ...
- IOS—UITextFiled控件详解
IOS—UITextFiled控件详解 //初始化textfield并设置位置及大小 UITextField *text = [[UITextField alloc]initWithFrame:CGR ...
- jQuery AJAX实例
<html><head><title>jQuery Ajax 实例演示</title></head><script language= ...
- 【BZOJ】1109: [POI2007]堆积木Klo
题意 \(n(1 \le n \le 100000)\)个数放在一排,可以一走一些数(后面的数向前移),要求最大化\(a_i=i\)的数目. 分析 分析容易得到一个dp方程. 题解 \(d(i)\)表 ...