移动端页面使用单位的问题:关于px、百分比、em、rem开发中逐渐转换的问题记录
开始写前端页面也有了快两年时间,从一开始的懵逼到现在的淡定,但是不能改变我还是一只小菜鸟的事实,平时遇到的一些问题都会记录在文件夹里,现在都整理一下大家一起分享自己平时也翻翻看看~
不知道大家平时写的时候是用的什么,但是我一般用的是这几个:px,百分比,em,rem
一、首先咱先了解下这几个都是啥,有啥区别:
px:就是像素,相对于屏幕分辨率而言的,简单来说就是平时我们写静态页面时用px作单位,但是在firefox/chrome会发现我们的布局发生了变化;
百分比:这比较适合块状的页面设计,但是他相对于不同屏幕而言的,比如经常在写移动端的时候也会用到
em:是相对长度单位,相对于父级元素的单位。如当前对行内文本的字体尺寸未被人为设置,则相对于浏览器的默认字体尺寸。就是当默认字体大小为14px,那么就有1em=14px;
rem:是相对于根元素,这样就意味着,我们只需要在根元素确定一个参考值。
二、平时用这些遇到的一些问题以及现在我最终使用的
平时写pc端页面时,没有疑问的,我选择的是px作为单位,遇到一些比较复杂的需要定位的也会夹杂使用百分比
主要来说说移动端页面:
1、刚开始接触移动端页面时,我用的是百分比和px,当时做出来就只对着一个手机进行调试,结果可想而知的,用不同浏览器测试时,有些布局就乱掉了,就算调整也不能完全还原设计图所设计的;
2、后面发现了使用em作为单位,它是相对长度单位但是是相对于父级元素的,相对于当前对象内文本的字体尺寸,当浏览器分辨率发生变化时,他会重新计算相对的长度的大小并展现出来
这个行内文本的字体大小是可以认为设置的,默认是14px,就有1em=14px,所以将页面里的px转化为em在显示是基本可以满足适应不同移动端浏览器的,下面我就开始了漫长的计算过程
因为不同移动端屏幕的分辨率是不一样的,而我们一般得到的设计稿是640px,那怎样才能在750px等更大写的屏幕上完美的显示出来呢:
这里我使用的是css3 媒体查询,先给页面设置一个字体大小为18px(也就是1em=18px)然后按不同的屏幕尺寸,分别计算不同屏幕下相对于18px的字体大小:
body {
font-size: 18px;
}
@media only screen and (max-width: 300px) {
body {
font-size: 16.666666px;
}
.viewport {
max-width: 300px;
}
}
@media only screen and (max-width: 310px) and (min-width: 300px) {
body {
font-size: 16.666666px;
}
.viewport {
max-width: 310px;
}
}
@media only screen and (max-width: 320px) and (min-width: 310px) {
body {
font-size: 17.22222px;
}
.viewport {
max-width: 320px;
}
}
@media only screen and (max-width: 350px) and (min-width: 320px) {
body {
font-size: 17.77778px;
}
.viewport {
max-width: 350px;
}
}
@media only screen and (max-width: 360px) and (min-width: 350px) {
body {
font-size: 19.44444px;
}
.viewport {
max-width: 360px;
}
}
@media only screen and (max-width: 400px) and (min-width: 360px) {
body {
font-size: 20px;
}
.viewport {
max-width: 400px;
}
}
@media only screen and (max-width: 470px) and (min-width: 400px) {
body {
font-size: 22.22222px;
}
.viewport {
max-width: 470px;
}
}
@media only screen and (max-width: 480px) and (min-width: 470px) {
body {
font-size: 26.11112px;
}
.viewport {
max-width: 480px;
}
}
@media only screen and (max-width: 540px) and (min-width: 480px) {
body {
font-size: 26.66666px;
}
.viewport {
max-width: 540px;
}
}
@media only screen and (max-width: 560px) and (min-width: 540px) {
body {
font-size: 30px;
}
.viewport {
max-width: 560px;
}
}
@media only screen and (max-width: 570px) and (min-width: 560px) {
body {
font-size: 31.11112px;
}
.viewport {
max-width: 570px;
}
}
@media only screen and (max-width: 630px) and (min-width: 570px) {
body {
font-size: 31.66666px;
}
.viewport {
max-width: 630px;
}
}
@media only screen and (max-width: 640px) and (min-width: 630px) {
body {
font-size: 35px;
}
.viewport {
max-width: 640px;
}
}
@media only screen and (max-width: 710px) and (min-width: 640px) {
body {
font-size: 35.55556px;
}
.viewport {
max-width: 710px;
}
}
@media only screen and (max-width: 720px) and (min-width: 710px) {
body {
font-size: 39.44444px;
}
.viewport {
max-width: 720px;
}
}
@media only screen and (min-width: 720px) {
body {
font-size: 40px;
}
.viewport {
width: 720px;
}
}
然后就可以计算出不同屏幕分辨率下的相对尺寸是多少px,在按照设计稿计算出em值(假设设计稿为640px,那么(1em=35px)),这真的是相当的麻烦,还得拿个计算器放旁边。。。
em是相对于父级元素变化的单位,所以当你的父级元素的字体大小发生变化时他也会跟着变化,这里又得计算。。。总之就是麻烦。。。我还用了好久。。。3、后来继续研究开始使用rem,最起码它是直接的相对于根元素变化的,感觉这是em的一个升级。。。
同样的这也是需要计算和设计初始的字体大小的,但是有个很便捷的路径,使用sublime text3里面的一个cssrem插件配合使用flexible.js,可以自动进行换算,省时省力,还省代码。当时有的时候还得配合使用百分比和px。
以上都是个人的小经验,也许大神门还有高招,本人还在不断学习中。。。
移动端页面使用单位的问题:关于px、百分比、em、rem开发中逐渐转换的问题记录的更多相关文章
- 弄懂css中单位px和em,rem的区别
国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什么优劣呢? PX特点 1. IE无法调整那些使用px作为单位的字体大小 ...
- [转]彻底弄懂css中单位px和em,rem的区别
难怪会问我 rem 和 em, 这俩或在移动端还是很有必要学习的. root em OK? 国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什么优劣呢? P ...
- 彻底弄懂css中单位px和em,rem的区别
国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什么优劣呢? PX特点 -1. IE无法调整那些使用px作为单位的字体大小: -2. 国外的大部分网站能够调 ...
- CSS中单位px和em,rem的区别
PX特点: 1 IE无法调整那些使用px作为单位的字体大小: 2. 国外的大部分网站能够调整的原因在于其使用了em或rem作为字体单位: 3. Firefox能够调整px和em,rem,但是96%以上 ...
- 彻底弄懂css中单位px和em,rem的区别 转的自己看
国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什么优劣呢? PX特点 1. IE无法调整那些使用px作为单位的字体大小: 2. 国外的大部分网站能够调整的 ...
- 【转载】彻底弄懂css中单位px和em,rem的区别
原文链接:http://www.cnblogs.com/leejersey/p/3662612.html 国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什 ...
- css中单位px和em,rem的区别[转载]
PX特点 1. IE无法调整那些使用px作为单位的字体大小: 2. 国外的大部分网站能够调整的原因在于其使用了em或rem作为字体单位: 3. Firefox能够调整px和em,rem,但是96%以上 ...
- 网页布局设计css中单位px和em,rem的区别
国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什么优劣呢? PX特点 1. IE无法调整那些使用px作为单位的字体大小: 2. 国外的大部分网站能够调整的 ...
- css单位中px和em,rem的区别
css单位中分为相对长度单位.绝对长度单位. 今天我们主要讲解rem.em.px这些常用单位的区别和用法. px(绝对长度单位) 相信对于前端来说px这个单位是大家并不陌生,px这个单位,兼容性可以说 ...
随机推荐
- centos下linux运行asp网站搭建配置-mono+nginx
一.首先安装一些需要的软件包 1. 首先更新CentOS上的软件包:yum –y update. 2. 安装一些需要的库: yum -y install gcc gcc-c++ bison pkg ...
- 【转】iOS超全开源框架、项目和学习资料汇总
iOS超全开源框架.项目和学习资料汇总(1)UI篇iOS超全开源框架.项目和学习资料汇总(2)动画篇iOS超全开源框架.项目和学习资料汇总(3)网络和Model篇iOS超全开源框架.项目和学习资料汇总 ...
- spring4 security 4 +websocket 实现单点登录
测试地址:http://sms.reyo.cn/ 帐号:aa 密码:123456 先看一下效果图: spring4 security 4 实现单点登录,而websocket 实现单点的下线通知
- phpredis中文手册——《redis中文手册》 php版
本文是参考<redis中文手册>,将示例代码用php来实现,注意php-redis与redis_cli的区别(主要是返回值类型和参数用法). 目录(使用CTRL+F快速查找命令): Key ...
- eclipse 和 android studio 编译时报 Unsupported major.minor version 52.0错解决办法
version 52.0 是java8的环境.当gradle tools 升级到2.2.1时候,可能编译时候会报该错误. 很多网友说更改java version,但是很多时候无效.下面是我遇到时候的解 ...
- SVO实时全局光照优化(里程碑MK2):Sparse Voxel Octree based Global Illumination (SVO GI)
自主实现的实时渲染引擎,对标对象ue4/ce5,超越u3d/klayge.MK2版本侧重于质量与速度的均衡,以下上传示范均为实测截图,均为全分辨率(网页上显示缩小了)1080p/60fps.
- Halcon学习标定助手
本文采用halcon标定助手进行标定. 第一步:打开标定助手. 第二步:对描述文件进行修改 具体:打开算子窗口,输入gen_caltab,进行描述文件修改. 参数XNum和YNum为7行*7列的圆,M ...
- U深度利用iso文件制作U盘启动盘
利用U盘装win10系统: 工具:U深度装机版 文件:win10.iso 步骤1:下载U深度装机版安装 步骤2:打开U深度,制作U盘启动盘,注意选择iso模式,如下图所示 接下来下一步即可,工具会 ...
- 在gradle 中使用ant 执行 “命令行”(CMD)不出日志解决方案
因为gradle 好恶心,声明的任务,一定会事先运行一次,而任务追加的话就不会 例如: task hello(){ println "HelloWorld" } task hell ...
- RHEL 6 或者 Oracle Linux 6, 不关机识别新添加的scsi硬盘
下面看一下在系统不重启的情况,如何让系统认识新的磁盘,并能对其分区与格式化1.在开机状态下新增磁盘2.执行下面的命令 echo "- - -" > /sys/class/sc ...