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

说明: 以主流的iPad、iPhone为例。 
工具: Resizer官网: Resizer 
用法: 将通栏处写有 “Click or Bookmark”的蓝色按钮拖拽至标签栏(加入收藏,注意,不是上面的官网地址) 。先 打开要进行测试的页面 ,再点击 已加入收藏夹的标签 即可。此时被测试页面顶部会多出一条工具栏,于是就可以根据需求任意进行测试。 
分辨率 :预设的分辨率有(可切换横版,竖版) 
普通智能手机:320×480 
iPhone5:320×568 
普通平板:800×600 
iPad2、3、mini:768×1024 
宽屏电脑:1280×800 
HDTV:1920×1080 
另外,也可以自定义分辨率。

二、meta标签

1)    <meta name="viewport" content="width=device-width; initial-scale=1.0; maximum-scale=1.0; user-scalable=0;" />
//强制让文档的宽度与设备的宽度保持1:1,文档初始化缩放比例是1:1,且不允许用户点击屏幕放大浏览,尤其要注意的是content里多个属性的设置一定要用分号+空格来隔开,如果不规范将不会起作用。
其他属性有:
width;
height;
initial-scale;
minimum-scale;
maximum-scale;
user-scalable; 2) <meta name="apple-mobile-web-app-capable" content="yes" />
//iPhone私有标签,它表示:允许全屏模式浏览 3) <meta name="apple-mobile-web-app-status-bar-style" content="black" />
//iPhone私有标签,它指定的iPhone中safari顶端的状态条的样式 4) <meta name="format-detection" content="telephone=no; email=no" />
//不识别邮件和不把数字识别为电话号码

二、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,流体盒模型,这是一种自适应的解决方案。 点此详情

四、javascript库

1.retina.js (官网貌似打不开了,另附 下载通道 ) 
有很多设备的“devicePixelRatio”都大于1.5或者等于2(window.devicePixelRatio = 物理像素/dips)。 移动端web app上CSS要为Retian屏幕准备另外的图片及代码: 
方法一:

<script type="text/javascript" src="<路径>/retina.js"></script>//使用方法
<style>
.logo {
background-image: url('/images/my_image.png'); //通用屏幕
} @media all and (-webkit-min-device-pixel-ratio: 1.5) { //当使用Retina屏幕时,读取此段样式
.logo {
background-image: url('/images/my_image@2x.png');
background-size: 200px 100px; //限定大图片的大小
}
}
</style>

方法二:

<img src="/images/image.png" /> //通用屏幕
<img src="/images/my_image.png" data-at2x="<路径>/image@2x.png" /> //retina屏幕

2. fastclick.js 
说明 : 这个要重点介绍一下! 
当触发"Click"事件时,移动端浏览器将等待约300毫秒的时间后再做出响应,这样的原因是浏览器要判断用户是否执行双击。 
导入 fastclick.js 即可减少这个时间差:

<script type='application/javascript' src='/path/to/fastclick.js'></script>

jQuery 使用方法:

$(function() {
FastClick.attach(document.body);
});

五、其他技巧

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

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

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

    -webkit-box-sizing:border-box;
    //用来指定该盒子的大小包括边框的宽度。
  4. 自动大写与自动修正 
    关闭这两项功能,可以通过autocapitalize 与autocorrect 这两个选项

    <input type="text" autocapitalize="off" autocorrect="off" />
  5. <link rel="stylesheet" media="all and (orientation:portrait)" href="portrait.css" />
    // 肖像模式样式
    <link rel="stylesheet" media="all and (orientation:landscape)" href="landscape.css" />
    // 风景模式样式

    方法二:

    //肖像模式样式
    <style media="all and (orientation:portrait)" type="text/css">
    #landscape { display: none; }
    </style> //风景模式样式
    <style media="all and (orientation:landscape)" type="text/css">
    #portrait { display: none; }
    </style>

Web App 响应式页面制作 笔记整理的更多相关文章

  1. web app响应式字体设置!rem之我见

    之前做沙漠教育的时候,直接以设计图为准,然后强暴式,缩放处理.简单.直接,粗暴!但是,开发快.……一劳永逸! 但那是,现在开发,作为业界良心:是不能那么做的!(那个是被逼的啊 首先看代码: @medi ...

  2. css考核点整理(十一)-响应式开发经验,响应式页面的三种核心技术是什么

    响应式开发经验,响应式页面的三种核心技术是什么

  3. css考核点整理(十)-响应式开发经验,响应式页面的三种核心技术是什么

    响应式开发经验,响应式页面的三种核心技术是什么

  4. html5/css3响应式页面开发总结

    一,自适应和响应式的区别 自适应是一套模板适应所有终端,但每种设备上看到的版式是一样的,俗称宽度自适应. 响应式一套模板适应所有终端,但每种设备看到的版式可以是不一样的. 虽然响应式/自适应网页设计会 ...

  5. HTML5入门教程:响应式页面布局

    摘自:https://www.sohu.com/a/225633935_647584 随着互联网时代的发展,我们对网页布局有了新的要求,大气,美观,能够在不同的设备上呈现令人焕然一新的效果.此时,一个 ...

  6. python 全栈开发,Day57(响应式页面-@media介绍,jQuery补充,移动端单位介绍,Bootstrap学习)

    昨日内容回顾 ajax //get post 两种方式 做 请求 get 主要是获取数据 post 提交数据 同一个路由地址 既可以是get请求也可以是post请求 一个路由对应一个函数 get请求 ...

  7. web前端响应式布局,自适应全部分辨率

    写phpd的我. 近期公司要弄个app关键是没有web开发,而我有比較闲,那就扛枪上阵吧. 响应式布局,web端的?php我一直都是用tp框架,对于web首先想到的是bootstrap框架.仅仅是简单 ...

  8. html5 getComputedStyle + resize 实现动态宽高度等比响应式页面设计

    序:通常我们只能控制div的宽度 而不能控制高度,在响应式页面里 如果要这个div是正方形那么必须的用媒体查询在不同的分辨率下写死宽高度 今天突发奇想研究了个 用百分比来动态控制div的高度让其与宽度 ...

  9. 响应式页面-@media介绍

    01 响应式页面-@media介绍,   我们为什么要写自适应的页面(响应式页面) 众所周知,电脑.平板.手机的屏幕是差距很大的,假如在电脑上写好了一个页面,在电脑上看起来不错,但是如果放到手机上的话 ...

随机推荐

  1. Rsync 12种故障排查及思路

    Rsync 故障排查整理 Rsync服务常见问题汇总讲解: ====================================================================== ...

  2. DEV—【GridControl主从表】

    先附上效果图,不是想要这个效果的朋友就不用可以继续寻找了. DEV—GridControl制作主从表: (注:此例没有用到数据库,只是单纯的在内存中操作数据.) 写这一笔,是为了能更好的理解主从表,的 ...

  3. API系列一:REST和RESTful认识

    序言 最近工作的项目一直使用API,就想趁這个机会,把API的知识点进行一次梳理和总结,顺便提升一下自己对API全新的认识 Web API 是ASP.NET平台新加的一个特性,它可以简单快速地创建We ...

  4. (二)Spring容器

    大佬总结的很好,请去看大佬博客. http://www.cnblogs.com/chenssy/archive/2012/11/15/2772287.html https://www.cnblogs. ...

  5. IIS 安装了.net framework 4.0/4.5 却找不到相应应用程序池

    通常情况下是因为没注册造成的,有些安装包会自己帮你注册上有些不会,感觉略坑. 注册方法:在计算机中点击 开始菜单–>运行 拷贝以下内容运行一下即可. C:\WINDOWS\Microsoft.N ...

  6. was--创建概要文件(典型)

    1.第一步 2 .创建 3.创建 4 .典型 5  下一步 6 下一步   7.下一步   8.输入用户和密码,下一步 9.下一步 10.下一步 11.下一步 12.下一步 13.下一步 14.创建 ...

  7. 慎将MBTI测试用于招聘或就业:4星|《人格魅力修炼指南》

    人格魅力修炼指南:成为理想中的自己,就靠它了!(<哈佛商业评论>增刊) <哈佛商业评论>的11篇领导者人格魅力相关的文章.比较专业. 一些重要的信息:慎将MBTI测试用于“招聘 ...

  8. iTOP-4418开发板最新资料及例程

    开发板资料: 开发板硬件资源: 1.POWER电源接口 电源输入为 5V/2A+,给核心板 AXP228 电源管理芯片提供 5V 电源. 2.SWITCH电源开关 轻触电源开关可以控制开发板电源通断. ...

  9. libevent学习之网络通信

    服务器端要实现网络通信,肯定会用到socket等函数,这几个函数应该没什么问题.libevent默认情况下是单线程的,可以配置成多线程,每个线程有一个event_base,对应一个struct eve ...

  10. CREATE LANGUAGE - 定义一种新的过程语言

    SYNOPSIS CREATE [ TRUSTED ] [ PROCEDURAL ] LANGUAGE name HANDLER call_handler [ VALIDATOR valfunctio ...