絮叨絮叨 | 关于html5中各端适配

讲起html5,一般而言developer都会知道bootstrap,bootstrap是世界第一大响应式框架,然鹅...剧情需要,UI并不会围绕bootstrap来设计,为了需求,你需要自己来完成各端适配。

先说bootstrap,它根据媒体查询来根据查询到的媒体宽定义显示宽,拿到宽整除12来得到每节的大小,讲真,分12份艺术层面讲我不太懂,一般是够用的,让你设计页面的时候可以以1,3为整除,让你用起来会走上艺术路线,而且你会发现你设计的页面会根据屏幕大小而自然适应,当然,你可能从此失去设计要求。

在移动端页面CSS像素级问题上,可能你会感受到,宽10px高10px的黑色背景小块 或者 14px的字,在不同端显示的大小差别很大

这个是因为

css-px与设备px

理论上,我不太想讲这些术语上的东西,什么dpi,什么viewport。。但是你都要了解,至少多看几个帖子。。

物理级的东西讲太多容易乱,我就不墨迹了!

推介:

《此像素非彼像素》:http://www.w3cplus.com/css/A-pixel-is-not-a-pixel-is-not-a-pixel.html

《淘宝弹性布局方案lib-flexsize实践》:http://mp.weixin.qq.com/s/CJntnUqYoCaqnq5Wp4MakQ


HTML5中我们要做到让UI图按照比例自成,让你分配页面像素,那么我们如何拿到这个比例?又要根据什么作为屏幕划分?这个问题问的好,HTML5中有这么一个东东他叫rem,em。

说通俗点:怎么在各个屏幕拿到一个可以值,那么rem、em就是那个你想要的。

rem:根节点字体大小

em:父元素字体大小

first,long long ago ... 我都是这么搞事情的,

拿到屏幕宽度

根据上文,我们可以设置根元素字体  即rem的大小

赋值给根元素一个字体大小

这时候你可以试着打印html的font-size:document.getElemntsByTagName('html').style.fontSize

如果你的页面设置为iphone6的情况下,你会得到这样的一个值

84.1667px

当前你拿到的window.innerWidth的值是375

总宽除以这个fontSize刚好12倍

那么这样,你就得到现在你的rem=84.1667px,当你在拿到设计图的时候,你就知道1rem是多少,正比你要的尺寸,就可以得到应该赋值多少

比如:设计给100px,100/84.1667 = ? 那你就得到这个值 (100/84.1667)rem可以得到100px在移动端显示的值

注意:

1>这种方法适用于任何移动端适配,但是算起来会比较费劲。

2>如果你用sass的情况下需要设计一个函数来帮你计算rem,但是这种方法还是会很难受,理解起来很不方便。

3>当然这种方法你需要给你的meta标签加入viewport属性。记得要有deviceWidth


than,经过不屑的专研,找到一种更为合适的方法,就是淘宝现框架里面的flex-size

下面来激情要来了!!!!

flex-size根据不同手机计算dpr值,并赋值一个固定的值给根元素,同样是rem

m.taobao.com

可以看到iphone6的情况下,fontSize为75px。

经过本人多次实验,现在我们拿到的75px只是一个基数,怎么这样说?

其实很简单,你加入flex-size这个js文件之后呢,你会得到一个比例值,这个比例的根值为75px。

一般设计给你的设计图都是苹果6的样式,如要还原你可以想到,如果要配合各种设备,各种设备在浏览器端的fontsize是会变得,那么你的设计图应该怎么在这种轮询下跟着变换?

很简单,你需要给你设计标注的所有px值直接除以75px,再赋值单位rem,你就得到你应该拿到的值

flex-size你可以直接得到一个全局的rem属性,在你的script中设置css的时候也可以直接拿到来使用,非常方便

简单点,我都是这么写的。

sass配置

@include commen-area(to-rem(179),to-rem(64))里,179代表设计图宽度,67代表设计图高度

就酱紫,是不是很简单!!!

当然你如果不想用sass,那你可以自己直接计算,整体很简单。

加入flex无需定义拿到当前rem

使用flex-size以后你只要在你的页面里面加入这个东东就好了,剩下的一概不用。什么viewport都不需要,自然都给你加好了。。。

head设置

好了,大概就这么些。。没啥太多的。希望对你有用~~~~

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

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,741评论 1 92
  • 前言 对于熟悉pc端的小伙伴来说,对于静态页面的布局,一般都是没有什么问题的,为了保持各浏览器显示的一致性,无论是...
    itclanCoder阅读 13,645评论 5 61
  • 移动开发基本知识点 一.使用rem作为单位 html { font-size: 100px; } @media(m...
    横冲直撞666阅读 3,460评论 0 6
  • H5移动端知识点总结 阅读目录 移动开发基本知识点 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇阅读 4,449评论 0 26
  • 这两天游很多重要的感悟,可能是奠定我20年之后,能否收获大的胜利的果实的重要的前因。最重要的就是懂得了什么是真正的...
    玥貉阅读 604评论 0 0