webapp,liveapp: 流式布局和rem布局
liveapp场景应用,一般针对的是移动端,近来也是很火,颇有一些感受,拿来分享一下。
页面宽度范围:
一般移动端页面我们的像素范围是320px-640px,最大640px,最小320px,所以设计稿就是按照640px来做
布局方式:
流式布局,百分比布局和rem。
目前我用过的主要是这rem和流式布局
流式布局:
网页的主要架构部分按照百分比布局,宽度百分比,高度定死;
如果是图片宽度设置百分比,高度根据图片的比例自适应,如果是封面图片可以高度定死,用background-size:cover显示部分就行;
一些具体的内容直接用像素定宽高就行了,比如用户头像,一些按钮,一些比较固定的文字。
下面这个页面就是流式布局,分别是640和320情况下的样子,下面的页面不是场景应用,只是举例
流式布局一般偏向于文字展示的页面,对整个页面比例要求不那么高的。
专门说说rem布局:
rem就是偏向于图片较多,不出现滚动条的满屏页面,且高度还原设计图比例的情况,所以下面的例子是基于满屏页面的情况。
关于rem的具体介绍参考 腾讯的rem文章http://isux.tencent.com/web-app-rem.html
因为rem是根据html的字体像素确定它的值,也就是html{font-size:20px}时 1rem==20px。
总之我们可以用js获取到屏幕的宽高后,通过修改html的font-size来控制整个页面的大小,来达到完整并高度还原设计稿。
我们的宽度范围仍然是320-640,我们怎么定义html的字体像素范围呢。
我们需要用字体像素对应320-640,比如font-size为10px的时候对应320px,那么确定10px为最小的基数,那么对应关系就会如下:
font-size | 1rem | 宽度 | 用rem表示宽度 |
10px | 10px | 320px | 32rem |
20px | 20px | 640px | 32rem |
但实际上我更喜欢这样:
font-size | 1rem | 宽度 | 用rem表示宽度 |
20px | 20px | 320px | 16rem |
40px | 40px | 640px | 16rem |
因为低于12px在某些浏览器里是默认还是为12px,因此当我们给html设置font-size:10px的时候,这时还是12px,就会对布局造成影响。
所以一般我以20px作为基数对应320px。
还有比如iphone4里,在微信下浏览器的高度比较矮,这时我们为适应高度的还会把font-size设置到18px左右,这样才可能显示完整。
好现在,我们设置body的宽度为16rem,根据当前屏幕的宽度修改html的跟字体大小
如果屏幕宽度大于等于640px,我们就设置为40px,小于等于320px就设置为20px。
如果是在320,640之间,就用对应的rem去计算,比如20px为320px基数时候,rem最大的值是16rem,16就作为基数去除屏幕宽度,
比如当前屏幕宽度是400px,那么根字体大小就是 400/16=26px
以下是js resize:
window.onresize = function(){
resize();
} function resize(){
//html:20px: 16rem 320px
//html:40px: 16rem 640px
var base = 16;//rem var wid = $(window).width();
var hei = $(window).height();
if(hei < 460){//适应个别高度较矮的设备
$('html').css('font-size', '18px');
return;
}
if(wid < 320){
$('html').css('font-size', '20px');
return;
}
if(wid > 640){
$('html').css('font-size', '40px');
return;
}
$('html').css('font-size', wid/16 + 'px');//在320和640之间,除以16的基数,来算font-size
}
resize();
基于rem,我们几乎都可以用绝对定位,相对于body就行了。
比如我们的设计稿,设计稿是640px的,对应的最大的font-size:40
有一个按钮宽度是200px,高度是100px,相对于图片左边距是40px,相对于图片上边距是80px。
那么我们的css就应该这样写:
.button{
position: absolute;
width: 200/40rem;(5rem) // 200px/40px = 5rem
height: 100/40rem;(2.5rem)
left: 40/40rem;(1rem)
top: 80/40rem;(2rem)
}
如果我们的设计稿是320px,按钮宽高边距和上面一样,那么我们css就应该这样写:
.button{
position: absolute;
width: 200/20rem;(10rem) //200px/20px = 10rem
height: 100/20rem;(5rem)
left: 40/20rem;(2rem)
top: 80/20rem;(4rem)
}
这样布局起来会省很多事情。
百分比布局:
还有一种就是单纯的百分比布局,也是全部用绝对定位,和以上rem不同的就是,用的百分比作为宽高边距的单位,这种方式并不推荐,控制力不强。
以下是一些心得:
1.fastclick最好都要使用
2.基于微信开发的时候,微信缓存非常厉害哟,有一次改了几个小时代码一直不对,最后发现是微信缓存,有时候不得不去系统管理里关闭微信和微信缓存进程。
3.最好还是用构建工具,比如gulp、grunt
4.做一个通用的demo start,供下次使用,包括gulp等构建工具,常用的三方和自定义的less、css loading,js相关文件和三方库
5.写一个图片预加载,未加载完前显示css loading,加载完了再显示页面,
以下是预加载的代码,主要针对一些大图片做加载,因为一般主要的大点的图片加载完,页面都会加载完,这算是一种小技巧吧,实际的精度也不差:
//图片预加载
function preloader(images, cb){
i = 0;
var onComplete = function(e){
i++;
if(i == images.length){
cb && cb();
}
}
for(j in images) {
var img = new Image();
img.onload = img.onerror = onComplete;
img.src = images[j];
}
} var onImgLoaded = function(){
$(".loading").addClass("hide");
/*显示正式页面*/
} //使用
preloader(["/img/guide.png","/img/combine-list-bg.png","/img/frontpage-words.png","/img/frontpage-bg.png"], onImgLoaded);
6.弹框居中的方式,推荐用下面代码:
.tf-center{
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
-webkit-transform: translate(-50%, -50%);
-moz-transform: translate(-50%, -50%);
-o-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
}
webapp,liveapp: 流式布局和rem布局的更多相关文章
- 你不知道的css各类布局(五)之em布局、rem布局
em布局/rem布局 em和rem的区别 在了解弹性布局前我们需要先知道em和rem rem:font size of the root element,rem是相对于根元素<html>来 ...
- 手机端布局,rem布局动态获取根字体大小
手机端布局,rem布局动态获取根字体大小. 以下代码: //rem布局动态获取根字体大小 function remDynamicLayout(){ var $windowWidth = $(windo ...
- 浅谈静态布局、流式布局,rem布局,弹性布局、响应式布局
静态布局: 特点:没有兼容性问题 PC:居中布局,所有样式使用绝对宽度/高度(px),设计一个Layout,在屏幕宽高有调整时,使用横向和竖向的滚动条来查阅被遮掩部分:移动设备:另外建立移动网站,单独 ...
- 响应式自适应布局代码,rem布局
响应式自适应布局代码 首先是先设置根字体大小,PC端一般是16px为根字体,移动端会有不同的,根据情况来设置 js部分 document.querySelector('html').style.fon ...
- 响应式布局(rem布局),使用JS动态设置fontsize
var cw = document.documentElement.clientWidth; if (cw > 1920) { cw = 1920; } document.getElements ...
- 静态布局、自适应布局、流式布局、响应式布局、弹性布局简析、BFC
静态布局:给页面元素设置固定的宽度和高度,单位用px,当窗口缩小,会出现滚动条,拉动滚动条显示被遮挡内容.针对不同分辨率的手机端,分别写不同的样式文件.例如:浏览器窗口是1000px,那么最小的宽度是 ...
- 在rem布局下使用背景图片以及sprite
现在移动端页面用rem布局已经是一大流派了,成熟的框架如淘宝的flexiable.js,以及我的好友@墨尘写的更轻量级的hotcss.用rem作单位使得元素能够自适应后,还有一块需要关注的,那就是背景 ...
- rem布局下使用背景图片和sprite图
现在移动端页面用rem布局已经是一大流派了,成熟的框架如淘宝的flexiable.js,以及更轻量级的hotcss.用rem作单位使得元素能够自适应后,还有一块需要关注的,那就是背景图片.本文就来聊聊 ...
- 流式布局&固定宽度&响应式&rem
我们现在在切页面布局的使用常用的单位是px,这是一个绝对单位,web app的屏幕适配有很多中做法,例如:流式布局.限死宽度,还有就是通过响应式来做,但是这些方案都不是最佳的解决方法. 1.流式布局: ...
随机推荐
- Ninja Blocks物联网平台简介
Ninja Blocks是一个物联网控制平台,其平台架构包括硬件层.处理器层.软件层以及平台层,请看下图: 最底层是硬件层,包括传感器(Sensors)和驱动器(Actuators),例如温度传感器. ...
- IrregularGridCollectionView处理不定宽度的标签cell
IrregularGridCollectionView处理不定宽度的标签cell 效果 源码 https://github.com/YouXianMing/UI-Component-Collectio ...
- InteliJ IDEA15 安装jrebel破解文件
使用InteliJ IDEA这个工具感觉比eclipse好用,例如它在没有源码的情况下自动反编译源码等,但是在使用的时,有个很不爽的地方就是不能实时编译,导致java代码更改了一点代码就需要重启项目, ...
- assertThat用法
一般匹配符1.assertThat( testedNumber, allOf( greaterThan(8), lessThan(16) ) ); 注释: allOf匹配符表明如果接下来的所有条件必须 ...
- HQ-SSAO (High-Quality SSAO)
踩了前前后后无数坑,实现方式都试过了10几种,终于得到这个方案.虽说比不上2015最新的far-field AO,但至少在near/middle-field上,算是state of arts的实现了. ...
- android:style.xml
<?xml version="1.0" encoding="utf-8"?> <!-- Copyright (C) 2006 The Andr ...
- 对list集合中的对象按照对象的某一属性进行排序
/** * 重新对list中的CmsCyUser对象按照最终的票数进行排序 * @param list */ private void reSort(List list) { Object[ ...
- sctp和tcp的区别
作为一个传输层协议,SCTP兼有TCP及UDP两者的特点.SCTP可以称为是TCP的改进协议,但他们之间仍然存在着较大的差别.首先SCTP和TCP之间的最大区别是SCTP的连接可以是多宿主连接的,TC ...
- ★android开发--ListView+Json+异步网络图片加载+滚动翻页的例子(图片能缓存,图片不错乱)
例子中用于解析Json的Gson请自己Google下载 主Activity: package COM.Example.Main; import java.util.HashMap; import ja ...
- C#记录对象的变化
经常,我们会遇到一个场景,在保存对象到数据库之前,对比内存对象和数据库值的差异. 下面我写了一种实现,为保存定义一个事件,然后自动找出对象之间的差异,请注意,并没有通过反射的方式去获取每个属性及其值. ...