响应式简单说呢就针对不同的屏幕分辨率应用不同的CSS样式。比如在电脑、Pad设备上,屏幕比较宽,就可以一行放2个Div。
到了手机上,或者Pad竖着拿的的时候,一行就只放1个Div。
这里有2个关键点:
一是如何在不修改Dom结构的前提下调整布局。
二是如何判断屏幕分辨率并应用对应的CSS。
以上两点都应该不依赖与JS。
实现第一点依靠的是流式布局。就是所有参与布局的DIV都用float:left,宽度都用百分比表示。比如下图,黄色部分的宽度是60%,橘色宽度是40%。
如果将黄色和橘色的宽度都width=100%,那么从1行变成2行了,如下图。从而实现不修改Dom实现布局变化。
那么如何不使用JS而实现动态调整CSS样式就是第二个关键点。 HTML5中提供了一种新的CSS语法——@media,学名是Media Query,可以为不同的分辨率设定不同的样式。
/* Phone Portrait (320px) */
@media only screen and (max-width: 320px) {
#head { width: 100%; }
#main { width: 100%; }
#foot { width: 100%; }
#left { width: 100%; }
#right { width: 100%; }
}
上面这段代码的含义就是当屏幕宽度小于等于320像素时应用大括号中的样式。下图是在CSS生效时在浏览器中的效果:
@media还有一些更复杂的用法,比如:
/* Phone Landscape (480px) */
@media only screen and (min-width: 321px) and (max-width: 480px) and (orientation: landscape) {
这段语句就是针对iPhone横屏的。即,浏览器宽度在321-480像素之间,且方向是“横向”时生效。
不过自从Retina这中妖艳的屏幕推出,分辨率已经不能代表世界的真相了。小小的Note3的分辨率比一些17“显示的分辨率还高。
所以还有必要判断一下设备的像素密度-device-pixel-ratio。
}
@media only screen and (-moz-min-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-device-pixel-ratio: 2)
比如上面的语句就是判断终端的像素比是2的话,所渲染的样式。可以适用于iPhone4,iPhone5等设备。
除了上述两点,还需要在页面上增加一个viewport的meta标签,否则在手机上可能会有页面自动缩放的情况。例如:
<meta name="viewport" content="width=device-width; initial-scale=1.0">
总结一下:响应式布局有三个关键点:
- 流式布局 Liquid Layout
- Media Query
- viewport
具体细节就请大家自己研究相关的语法了。
Media Query的语法比较复杂,这里个大家推荐一个工具,可以方便的设计布局,并可以针对各种设备自动生成Media Query的语句: http://www.responsivewebcss.com/
本文转载自腾讯AlloyTeam团队
你好,请问下你用的是什么代码高亮插件,方便告知一下吗?
做与不做的最大区别是:后者拥有对前者的评论权。
支持一下
转走不解释。
@小黎 你博客竟然在备案,好高端
有一种恶趣味的伪响应式,可以看看:<经通知,隐藏>
@c 我这里评论不能有外部网址,好了,已经从待审把你拯救出啦了,我的小公主
@Tokin ← ← 小公主……
@c 一看就是用你的程序做的,没有设计没有美感-_-
@Tokin 完了,这都能看出来,果然是我的设计太有特色嘛( ̄∇ ̄)
程序底层框架是我写的,还卖了那站长300块~~
你还是把这留言删了吧,那网站太危险……
@c 删掉干嘛,我网站哪里危险了- –
@Tokin 不不,我指<隐藏>太危险了……
@c 抱歉没说清楚,是本页里所有带“<隐藏>”的评论都帮我删掉。
包括评论id:8577、8593、8602还有这条评论。
(就是“有一种恶趣味的伪响应式”那条到这条的全部评论)
主要我和那站没啥联系了,目前不想有啥瓜葛。
十分感谢!!
@c 嗯,我去找找。
@c 现在呢,我都编辑了一遍
@Tokin 哈这样也好,多谢啦!!
楼主讲解的很详细,谢谢分享、
主题不错噢
做代码好麻烦
你有没有发现,现在评论部分不好看?还有head和footer 可以拔否?哈哈 😕
@东少 临时改的主题,现在响应式又要改,没时间弄
随便扒吧,哈哈
@Tokin 😀 那你直接吧代码给我吧。懒一把
@东少 都是HTML