css 移动端布局(一)

布局方式总结:
float(浮动) 、 position(定位i) 、table-cell(转表格)、flex(弹性盒)、

  1. 你的html跟文档字体设置为 10px; html {font-size: 62.5%;} ==> 62.5%*16 = 10 (1rem = 10px)
  2. 设计稿的宽度,高度,边框,一切大小都除以20,在进行设置rem (以iphone6为基准) 设计稿的宽度为750px, 750/2/10 除以2先把他缩小一半,和苹果6的屏幕一样大,在除以10,是把px单位转为remd单位
    那么你的字体例如设置 span { font-size: 1.4rem; } 其实就是 1.4rem * 10 = 14px; 因为html跟字体是10px;

3.表格移动端布局核心:

 1) 父div的display:table;  因为他已经为table了,所以设置宽度为100% (table, 100%俩个属性必须) 对于那些流白,因为没有设置宽和高度,所以我们用padding属性来撑开, 最好不要设置高度给他,适应就可以了 .container{ padding: 1rem 2rem; display: table; width: 100%;vertical-align: middle; }
 
 2)  子div设置为display:table-cell  这样他就拥有了表格那些特性,可以用vertical-align: middle;
      .left {display: table-cell;vertical-align:center;text-align:center; width:2rem; height:3rem;box-sizing: borer-box;(css3盒子模型,加padding保证盒子不外扩);font-size:1.4rem;(下面的子元素字体大小会继承)}
 
 3) 对应左右子div,一般有一个是自适应的,来适应屏幕的宽度,另一个设置宽度来固定,可以设置高度
     .right {display: table-cell;vertical-align:center;text-align:center;} 

4.字体最小不能小于1.2rem,一般是1.4rem
5.移动端初始化样式

a,b,body,canvas,dd,div,dl,dt,em,form,h1,h2,h3,h4,h5,h6,html,img,input,label,li,ol,p,q,span,ul{
  margin:0;
  padding:0;
  border:0;
  outline:0;
  font-size-adjust:none;
  -webkit-text-size-adjust:100%!important;
  -webkit-touch-callout:none;
}
*{-webkit-tap-highlight-color:transparent; padding: 0; margin: 0;}
input, textarea, keygen, select, button {font-size: 1.4rem}
extarea:disabled, input:not([type]):disabled, input[type="color" i]:disabled, input[type="date" i]:disabled, input[type="datetime" i]:disabled, input[type="datetime-local" i]:disabled, input[type="email" i]:disabled, input[type="month" i]:disabled, input[type="password" i]:disabled, input[type="number" i]:disabled, input[type="search" i]:disabled, input[type="tel" i]:disabled, input[type="text" i]:disabled, input[type="time" i]:disabled, input[type="url" i]:disabled, input[type="week" i]:disable {
  background-color: transparent; color: #888
 }
 
body,html{
    font-size:62.5%;   //---->>这里跟字体大小设为10px(62.5%*16 = 10)  1rem = 10px
    height:100%;
    padding:0;margin:0;
    background-color:#fff;
    font-family:'Microsoft YaHei';
}

input{-webkit-user-select:auto;-webkit-appearance:none;appearance:none;outline:0;}

::-webkit-input-placeholder{color:#999;}

li,ul{list-style:none;}

a{text-decoration:none; color: #4c4c4c;}

em{font-style:normal;}

.show{display:block!important;}

.hide{display:none!important;}

.bold{font-weight:bold!important;}

.fixed{position: fixed!important;}
.fl {float: left;}

.fr {float: right;}

.bdn{border: none!important;}

.cb{clear: both!important;}

 html,body{width:100%;max-width:768px;margin:0 auto;}
 
.mg_body_bggrey{ background-color: #f2f2f2 }

.mw_main{clear: both; border-bottom: 5rem solid transparent; background:#f2f2f2;}

.mw_new_loading{
   font-size:1.4rem;
   line-height:3rem;
   height:3rem;
   display:block;
   text-align: center;
   color: #898c8d;
}

html {-ms-touch-action: none;}

6.转表格布局一般用于:
1)左右两列 (一个定宽,一个去自适应,高度都用padding撑开)

  1. 左中右 (一般是左右定宽,中间去自适应)

7.图片解释


table_layout1.png
table_layout2.png
table_layout3.png
table_layout4.png
table_layout5.png
table_layout6.png
table_layout7.png
table_layout8.png
table_layout9.png
table_layout10.png
table_layout11.png
table_layout12.png

6.注意


7.display:table-cell用法
1). display:table-cell属性指让标签元素以表格单元格的形式呈现,类似于td标签
2). 我们都知道,单元格有一些比较特别的属性,例如元素的垂直居中对齐,关联伸缩等,所以display:table-cell还是有不少潜在的使用价值的,
3). 与其他一些display属性类似,table-cell同样会被其他一些CSS属性破坏,例如float, position:absolute,所以,在使用display:table-cell与float:left或是position:absolute属性尽量不用同用。设置了display:table-cell的元素对宽度高度敏感,对margin值无反应,响应padding属性,基本上就是活脱脱的一个td标签元素了。
对于不认识display:table-cell属性的IE6/7呢?哦呵呵,很简单,使用display:inline-block属性代替display:table-cell就完全ok的啦!display:table-cell; *display:inline-block;
作用:
A--->>display:table-cell与大小不固定元素的垂直居中
B--->>display:table-cell与两栏自适应布局
C--->>display:table-cell与三栏自适应布局
D--->>display:table-cell下的等高布局
父元素设置display:table;
左右两边都没有设置宽度,默认他们平分父元素的宽度,各占50%
左右两边有一侧设置宽度,另一测没有设置宽度,那么没有设置那一侧是自适应的(对于右侧是背景图的必须设置高度,才能撑开背景图片,右侧是文字的话就不需要了,padding即可)
三栏布局,一般左右固定,中间自适应即可

移动端布局使用table-cell
布局

其他详解:

  1. http://www.jianshu.com/p/2479665ee1f8
  2. https://www.qianduan.net/table-cell-di-shou-ji-ying-yong-chang-jing
  3. https://segmentfault.com/a/1190000003926015
    4)http://www.zhangxinxu.com/wordpress/2010/10/%E6%88%91%E6%89%80%E7%9F%A5%E9%81%93%E7%9A%84%E5%87%A0%E7%A7%8Ddisplaytable-cell%E7%9A%84%E5%BA%94%E7%94%A8/
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,440评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,814评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,427评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,710评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,625评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,014评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,511评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,162评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,311评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,262评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,278评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,989评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,583评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,664评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,904评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,274评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,856评论 2 339

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,721评论 1 92
  • ======= SEO专用 table-cell 定高水平垂直居中 不定高水平垂直居中 单行定高水平垂直居中 单行...
    木白no1阅读 10,367评论 1 15
  • H5移动端知识点总结 阅读目录 移动开发基本知识点 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇阅读 4,374评论 0 26
  • 移动开发基本知识点 一.使用rem作为单位 html { font-size: 100px; } @media(m...
    横冲直撞666阅读 3,448评论 0 6
  • 前言 温馨提示:本文较长,图片较多,本来是想写一篇 CSS 布局方式的,但是奈何 CSS 布局方式种类太多并且实现...
    sunshine小小倩阅读 3,111评论 0 59