干货分享:Web应用响应式页面制作

最近写移动端整理了一些入门级的知识,比较实用,如取消移动端的默认样式,取消点击表单后的延迟时间等,都是日常项目中碰到的问题,部分整理自网络,部分按照自己的理解,如果有更好的建议希望大家评论补充

一、移动端种类、分辨率大小

说明:以主流的iPad、iPhone为例。

工具:Resizer官网:Resizer

用法:将通栏处写有“Click or Bookmark”的蓝色按钮拖拽至标签栏(加入收藏,注意,不是上面的官网地址) 。先打开要进行测试的页面,再点击已加入收藏夹的标签即可。此时被测试页面顶部会多出一条工具栏,于是就可以根据需求任意进行测试。

分辨率:预设的分辨率有(可切换横版,竖版)

普通智能手机:320×480

iPhone5:320×568

普通平板:800×600

iPad2、3、mini:768×1024

宽屏电脑:1280×800

HDTV:1920×1080

另外,也可以自定义分辨率。

2.节省样式的加载

目前而言,要改变网站的配色方案或者写iPad专用的样式表,是通过如下代码:

@media only screen and (min-device-width:640px) { … }//例如,适应某设备的分辨率

其实,没有必要这样让你的样式表白白超载。可以通过下面这个方法去加载指定分辨率下的样式。

这样的好处是,只有当你的使用相应的设备,才能加载到相应的样式表。

二、meta标签

1)

//强制让文档的宽度与设备的宽度保持1:1,

//文档初始化缩放比例是1:1,

//不允许用户点击屏幕放大浏览,

//允许用户缩放到的最大比例,

//尤其要注意的是content里多个属性的设置一定要用分号+空格来隔开,如果不规范将不会起作用。

其他属性有:

width;

height;

initial-scale;

minimum-scale;

maximum-scale;

user-scalable;

2)

//iPhone私有标签,它表示:允许全屏模式浏览

3)

//iPhone私有标签,它指定的iPhone中safari顶端的状态条的样式

4)

//不识别邮件和不把数字识别为电话号码

三、CSS3 -webkit

1、问题描述:移动端表单类有圆角、阴影,点击链接时,有灰色底高亮等

1) 消除被点击元素的外观变化,所谓的点击后高亮:

-webkit-tap-highlight-color: rgba(255, 255, 255, 0);

2) 阻止旋转屏幕时自动调整字体大小:-webkit-text-size-adjust:none;

3) 解决字体在移动端比例缩小后出现锯齿的问题:-webkit-font-smoothing: antialiased;

4) 盒子阴影:-webkit-box-shadow: none;

5) 圆角:-webkit-border-radius: 0;

6) appearance 属性使元素看上去像标准的用户界面元素,

也可以取消默认的样式:-webkit-appearance: none;

7) 鼠标可以悬停在内容上(指向该内容)而不激活它(单击它):-webkit-touch-action: manipulation;

四、使用自适应模式布局

为了让用户在safari中正常的浏览网页,我们必须保证用户的设备处于任何一个方位时,safari都能够正常的显示网页内容(也就是自适应),而且自适应之后也不用考虑分辨率的问题。

比如:-webkit-box,流体盒模型,这是一种自适应的解决方案。

、App icon 制作

说明:所谓单机模式,其实就是通过把网站添加到主屏,由主屏进入并访问网站的一种方式。通常,app icon是自动截取网站的一部分截图。这样并不是很美观,但也可以通过代码来解决这个问题。

尺寸:在iPhone上的默认大小是57px,在iPad上是72px。icon原始图片建议尺寸为128px或者256,并且不建议自行添加光影效果,因为OS自带了。

// 若想去掉系统自带的反光效果,可以增加“-precompsed”属性。

App Icon 设计资源:

图标模板:App Icon Template

设计灵感:iOS Icon Gallery,Hongkiat

制作工具:MakeAppIcon,iconkit(付费软件)

其他技巧

Float属性替换

使用display:inline-block属性代替;因为float不适用于反向停靠和无法接受水平间隙

检测用户是通过主屏启动你的web app

从主屏启动的web app和浏览器访问web app最大的区别 是它清除了浏览器上方和下方的工具条,这样web app就更加像是native app了。

window.navigation.standalone

if(!window.navigation.standalone) {

…// do your magic

}

此外,还可以通过以下方式,停留在单机模式中。

//最简单的方法

onclick=”window.location.href=this.href; return false”>QmyO

//改进一下,写成函数

function openLink(anchor) {

window.location.href = anchor.href;

return false;

}

//调用

QmyO

//更广泛的使用,如页面导航

/* 创建一个全局点击事件监听器 */

document.addEventListener(“click”, clickHandler, false);

function clickHandler(e) {

var element = e.target;

/* 只处理锚标签元素 */

if (element.localName.toUpperCase() != ‘A’) {

return;

}

/* 忽略target属性。*/

if (!!element.getAttribute(‘target’)) {

return;

}

var url = element.href;

/* 忽略不符合https正则规范以为的内容并区分来源 */

var match = url.match(/^https?:\/\/(.+?)\/.*$/);

if (!match || match[1] != window.location.host) {

return;

}

/* 最后打开全屏幕视图的链接,来防止默认行为 */

window.location.href = url;

e.preventDefault();

}

//注意:当a标签含有子标签如:

这个脚本就不起作用了,因为接收事件的不是链接,而是img标签。

但其他情况下都能使用户留在单机模式内。当点击外部链接时,OS可能会跳至浏览器。

如何解决盒子边框溢出当指定了一个块级元素时,并且为其定义了边框,设置了其宽度为100%。在移动设备开发过程中我们通常会对文本框定义为宽度100%,将其定义为块级元 素以实现全屏自适应的样式,但此时,该元素的边框(左右)各1个像素会溢了文档,导致出现横向滚动条,为解决这一问题,可以为其添加一个特殊的样式:

-webkit-box-sizing:border-box;

//用来指定该盒子的大小包括边框的宽度。

自动大写与自动修正

关闭这两项功能,可以通过autocapitalize 与autocorrect 这两个选项

横板与竖版

方法一:

// 肖像模式样式

// 风景模式样式

方法二:

//肖像模式样式

#landscape { display: none; }

//风景模式样式

#portrait { display: none; }

转载请注明:前端徐远»干货:Web App 响应式页面制作笔记

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

推荐阅读更多精彩内容