成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

頁(yè)面架構(gòu)HTML+CSS ヾ(o???)? 常用居中&多列布局

dingding199389 / 1706人閱讀

CSS Reset 1.作用

(1)清除瀏覽器默認(rèn)樣式
(2)全局樣式定義

2.特別注意

(1)項(xiàng)目開發(fā)初期就定義好
(2)reset.css 在引入的時(shí)候一定要放在第一位
(3)不同的產(chǎn)品reset.css不一樣

3.table合并邊框間距
table {
  border-collapse: collapse; // 合并邊框
  border-spacing: 0; //邊框間距。當(dāng) `border-collapse` 值為 `seperate` 時(shí)生效

}
4.一個(gè)并不完整也并不通用的reset.css樣例
    html,body,h1,h2,h3,h4,h5,h6,div,dl,dt,dd,ul,ol,li,p,blockquote,pre,hr,figure,table,caption,th,td,form,fieldset,legend,input,button,textarea,menu{margin:0;padding:0;}
    header,footer,section,article,aside,nav,hgroup,address,figure,figcaption,menu,details{display:block;}
    table{border-collapse:collapse;border-spacing:0;}
    caption,th{text-align:left;font-weight:normal;}
    html,body,fieldset,img,iframe,abbr{border:0;}
    i,cite,em,var,address,dfn{font-style:normal;}
    [hidefocus],summary{outline:0;}
    li{list-style:none;}
    h1,h2,h3,h4,h5,h6,small{font-size:100%;}
    sup,sub{font-size:83%;}
    pre,code,kbd,samp{font-family:inherit;}
    q:before,q:after{content:none;}
    textarea{overflow:auto;resize:none;}
    label,summary{cursor:default;}
    a,button{cursor:pointer;}
    h1,h2,h3,h4,h5,h6,em,strong,b{font-weight:normal;}
    del,ins,u,s,a,a:hover{text-decoration:none;}
    body,textarea,input,button,select,keygen,legend{font:12px/1.14 arial,simsun;color:#333;outline:0;}
    body{background:#fff;}
    a,a:hover{color:#333;}
布局解決方案 居中布局 1.水平居中

父元素和子元素寬度未知。

child

要達(dá)到的效果是這樣:

方法一:flex + justify-content

主要代碼:

.parent { 
  display: flex;
  justify-content: center;
}

沒啥好解釋,直接看 神奇的flex實(shí)現(xiàn)栗子 吧 (~ ̄▽ ̄)~

方法二:absolute + transform

主要代碼:

.parent { position: relative; }
.child { 
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

原理是:left: 50%;在子元素的左側(cè)添加了一段距離,這段距離是父元素寬度的50%,接著因?yàn)閠ranslateX(50%) 設(shè)置百分比時(shí)的參照物是自身寬度,所以向左偏移了自身寬度的50%,就居中啦 ╮(‵▽′)╭

動(dòng)動(dòng)小手看看栗子

方法三:inline-block + text-align

主要代碼:

.parent { text-align: center; }
.child { display: inline-block; }

這種方法有一個(gè)問題是:parent設(shè)置了text-align: center;后, 因?yàn)檫@個(gè)屬性可繼承,會(huì)導(dǎo)致child中的文字也會(huì)居中,而這個(gè)效果是我們未必需要的,所以我們很多時(shí)候需要在.child中加一句 text-align: left;

自己看看栗子

方法四:table + margin

主要代碼:

.child { display: table; margin: 0 auto; }

table的特點(diǎn):寬度為內(nèi)容寬度 的塊狀元素,所以也可以用margin: 0 auto;居中。

優(yōu)點(diǎn):只設(shè)置子元素樣式就可以了,不需關(guān)心父元素。

看看栗子

不喜歡這第四個(gè)方案,table是辣么有語(yǔ)義的一個(gè)樣式,為什么隨便把人家變成table ( ̄. ̄)

2.垂直居中

父元素和子元素高度未知。

意欲達(dá)到的效果:

方法一:flex+ align-items
.parent {
  display: flex;
  align-items: center;
}

水平居中的方法一

栗子

方法二:absolute + transform
.parent { position: relative; }
.child {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

水平居中的方法二

栗子

方法三:table-cell + vertical-align
.parent {
  display: table-cell;
  vertical-align: middle;
}

vertical-align 可以作用在 inline元素,inline-table元素,以及table-cell元素上。

栗子

3.水平垂直居中

父元素和子元素寬高都未知。

方法一:flex + justify-content + align-items
.parent {
  display: flex;
  justify-content: center;
  align-items: center;
}

綜合了水平居中垂直居中的方法一

栗子

方法二: absolute + transform
.parent { position: relative; }
.child {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

綜合了水平居中垂直居中的方法二

栗子

方法三: absolute + margin: auto; (常用)
.parent { position: relative; }
.child {
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

栗子

方法四:[inline-block + text-align] + [table-cell + vertical-align]
.parent {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}
.child {
  display: inline-block;
}

栗子

多列布局 1.一列定寬 + 一列自適應(yīng)

left

right

right

方法1:float + margin
.left {float: left; width: 100px;}
.right { margin-left: 120px;} //有20px是間距
方法2:(對(duì)方法一的改進(jìn))float + margin + (fix)

因?yàn)榉椒?在低版本瀏覽器有兼容性問題,所以改進(jìn)一下。

// 首先在right外面加了right-fix這個(gè)div

left

right

right

CSS改動(dòng):

STEP1:

// .left 和 .right 設(shè)置暫時(shí)不變
.right-fix {float: right; width: 100%;}

效果為:(注意:我們把right-fix設(shè)置為白色背景,只是為了方便觀察。)

STEP2:

可以看到,由于right-fix寬度為100%,所以跑到了left下面一行。想要回到同一行,需要給right-fix設(shè)置一個(gè)負(fù)的margin-left值-100px。

.right-fix { margin-left: -100px; }

關(guān)于為什么設(shè)置了margin-left: 100px;就可以使得回到同一行呢?是因?yàn)樵O(shè)置了負(fù)的margin-left值之后,瀏覽器計(jì)算right-fix元素的寬度后,會(huì)加上-100px,也就是減掉100px,這也就是left的寬度,所以left 與 right-fix 加起來沒有超過整行的寬度。
想要進(jìn)一步了解負(fù)的margin值可以參考這篇文章:CSS布局奇淫巧計(jì)之-強(qiáng)大的負(fù)邊距

效果如圖:

STEP3:

不幸的是,因?yàn)閔tml文檔中right-fix處于left后面,所以left被right-fix遮住了,實(shí)際應(yīng)用中right-fix雖然沒有背景色,但是我們還是不會(huì)希望它覆蓋在left上面。

所以,我們需要提高 left 的層級(jí)。如何提高呢?由于設(shè)置了position: relative;的元素層級(jí)要高于普通元素,所以加上這樣一條:

.left{ position: relative; }

具體可以參考張?chǎng)涡駥懙囊黄v解position:relative;很詳細(xì)的文章:CSS 相對(duì)/絕對(duì)(relative/absolute)定位系列(四)

最終達(dá)到我們要的效果:

到j(luò)sfiddle中自己試試去

方法3:float + overflow
.left{
  width: 100px;
  margin-right: 20px;
}
.right {
  overflow: hidden;
}

原理是:設(shè)置了overflow:hidden; 之后,會(huì)觸發(fā)BFC模式,而BFC模式內(nèi)部的布局不受外部影響,所以不會(huì)受浮動(dòng)影響,不會(huì)圍繞left而是跑到left右邊去了。

方法4:table
.parent{
  display: table;
  width: 100%;
  table-layout: fixed; //加速table渲染,實(shí)現(xiàn)了布局優(yōu)先
}
.left, .right {
  display: table-cell;
}
.left {
  width: 100px;
  padding-right: 20px;//因?yàn)閠able-cell不能設(shè)margin,所以設(shè)置padding來加間距
}

根據(jù)table的特性,left設(shè)置了100px后,right就占了剩余寬度。

方法5:flex
.parent{ display: flex; }
.left{ width: 100px; margin-right: 20px; }
.right{ flex: 1; }

So easy.

2.多列定寬 + 一列自適應(yīng)

再加一列定寬就行啦 o(≧v≦)o

3.不定寬 + 一列自適應(yīng)

不定寬意思是:
1.可以隨意更改寬度:比如改為100px,200px,同時(shí)不需要更改其他樣式也可以做到兩列自適應(yīng)布局。
2.或不設(shè)置寬度而是由里面子元素的寬度決定。

以下方法對(duì)應(yīng) [一列定寬+一列自適應(yīng)] 中的方法

方法1: float + margin ?

不好意思,做不到。

方法2: float + margin +(fix) ?

不好意思,也做不到。

方法3: float + overflow ?

闊以!right的樣式?jīng)]有依賴于width的寬度。代碼量也少,很棒棒哦!

方法4:table

闊以!right的樣式?jīng)]有依賴于width的寬度,即不關(guān)心width的寬度。

方法5:flex

強(qiáng)大的flex當(dāng)然可以~(傲嬌臉 )

4.兩列不定寬 + 一列自適應(yīng)

沒錯(cuò),跟你想的一樣,加一列不定寬的就行了,樣式都一樣 ㄟ( ▔, ▔ )ㄏ

5.等分布局

C + G = 4*(W + G)
以下例子假設(shè)間距G = 20px

結(jié)構(gòu):

1

2

3

4

方法1:float

.parent{ margin-left: -20px; }//就是上面公式中等號(hào)左邊的G
.column{
  float: left;
  width: 25%;
  padding-left: 20px;//這里要注意,因?yàn)槲覀冇胮adding來表示間距,所以如果你是給p元素設(shè)置了background-color,會(huì)發(fā)現(xiàn)沒有間距,p標(biāo)簽的width才是上圖中的W
  box-sizing: border-box;
}

方法2:table

1

2

3

4

.parent-fix{
  margin-left: -20px;
}
.parent {
  display: table;
  width: 100%;
}
.column {
  display: table-cell;
  padding-left: 20px;//因?yàn)閱卧癫荒茉O(shè)置margin,所以間距只能用padding來做。
}

因?yàn)閠able的width默認(rèn)是隨內(nèi)容寬度變化的,所以需要手動(dòng)設(shè)置width: 100%;。又因?yàn)槊鞔_設(shè)置了寬度的元素就沒辦法用將margin設(shè)為負(fù)值的方式增加20px寬度了,所以需要在外面加一個(gè)父元素parent-fix。
這里大家可以自己試試比較一下給parent-fix設(shè)置width為100%不設(shè)置width時(shí)parent-fix實(shí)際寬度(用調(diào)試工具里的查看元素看)的區(qū)別來理解。

吶,jsfiddle示例在這

方法3:flex

.parent { display: flex; }
.column { flex: 1; } 
.column + .column { margin-left: 20px; }//好用的兄弟選擇器 (??`ω′?)
6.一列定寬+一列自適應(yīng)(當(dāng)其中較高的一列高度變化,另一列同步變化)

右側(cè)變高,左側(cè)高度隨之變化:

↓↓

方法1:table

table的列之間有天然等高的特性。

就是上面 1.一列定寬 + 一列自適應(yīng)中的方法4:table

方法2:flex

flex也是天然的等高 <( ̄︶ ̄)> 因?yàn)樗J(rèn)的align-items為stretch,即在交叉軸上默認(rèn)拉伸占滿整個(gè)容器。

仍舊是上面1.一列定寬 + 一列自適應(yīng)中的方法5:flex。

簡(jiǎn)單到不好意思給栗子

方法3:float

仍舊是參照上面1.一列定寬 + 一列自適應(yīng)中的方法3:float + overflow,float并沒有天然等高,所以要在這個(gè)基礎(chǔ)上做改動(dòng)。

.left{
  width: 100px;
  margin-right: 20px;
}
.right {
  overflow: hidden;
}
//增加部分
.left, .right{
  padding-bottom: 9999px;//使得有背景色的部分變的很高
  margin-bottom: -9999px;//用負(fù)的margin抵消掉很高的padding,讓高度變回left和right中較高的那部分的內(nèi)容高度,以便parent用overflow: hidden;去隱藏掉超出部分
}
.parent {
  overflow: hidden;//隱藏掉超出邊界的部分 
}

其實(shí)left的實(shí)際高度并沒有變,是一種偽等高,只是背景變高。

栗子

7.全等四宮格

這是練習(xí)題,置幾試試吧。

1
2
3
4

方法1:flex

.parent {
  display: flex;
  flex-wrap: wrap;
  align-content: space-between;
}
.outer {
  flex-basis: 100%;
  display: flex;
  justify-content: space-between;
}

一顆僅供參考的栗子

方法2:float

我的栗子

方法3:table

一個(gè)栗子不一定對(duì)

全屏布局 1.定寬(px)+自適應(yīng)

只有主內(nèi)容區(qū) right 隨內(nèi)容滾動(dòng)。

方法1.position

top
left
right
bottom
html, body, .parent {height: 100%; overflow: hidden;}//為了讓整個(gè)頁(yè)面不滾動(dòng)
.top {
  position: absolute;
  top: 0; 
  left: 0; right: 0; //注意這個(gè)很棒的設(shè)置!可以自動(dòng)占滿整行 ヾ(o???)? 
  height: 100px;
}
.left {
  position: absolute;
  left: 0;
  top: 100px; bottom: 50px;
  width:200px;
}
.right {
  position: absolute;
  left: 200px; right: 0;
  top: 100px; bottom: 50px; //這也是上下占滿除了top和bottom之外的所有高度
  overflow: auto;//讓主內(nèi)容區(qū)可以滾動(dòng)
}
.help-right {//假裝有很多內(nèi)容
  width: 1000px;
  height: 1000px;
}
.bottom{
  position: absolute;
  bottom: 0; 
  left: 0; right: 0;
  height: 50px;
}

動(dòng)手寫寫才記得住

方法2.flex

top
left
right
bottom
html, body, .parent {height: 100%; overflow: hidden;}
.parent {display: flex; flex-direction: column;}
.top { height: 100px; }
.middle {flex: 1; display: flex;}
.left { width:200px; }
.right { flex: 1; overflow: auto; }
.help-right { width: 1000px; height: 1000px; }
.bottom{ height: 50px; }

栗子

2.百分比定寬(%)+自適應(yīng)

方法1.position , 方法2.flex :

把原來的用px寫的定寬改成百分比就可以了。是相對(duì)于body的高度和寬度來變化的。感覺top和bottom高度設(shè)置百分比不是很實(shí)用。

3.自適應(yīng)+自適應(yīng)

方法1.position

定寬的高度和寬度影響旁邊欄的布局,所以實(shí)現(xiàn)不了 - 。-

方法2.flex

闊以實(shí)現(xiàn),而且相當(dāng)簡(jiǎn)單 ╮(╯▽╰)╭ 把剛剛設(shè)置了高度和寬度的地方去掉就可以了 ∑(っ °Д °;)っ

驚人的栗子

方法3.Grid

闊以實(shí)現(xiàn),但是因?yàn)檫€是W3C的草案,所以會(huì)經(jīng)常變化,不穩(wěn)定,而且瀏覽器支持也不好。

響應(yīng)式 想要達(dá)到的效果

只寫一個(gè)網(wǎng)站,在多個(gè)終端顯示,在小屏幕上會(huì)隱藏部分元素。

現(xiàn)在的情況

在PC端瀏覽器中可以正常訪問的網(wǎng)站,到了手機(jī)上之后,內(nèi)容就會(huì)變得特別小。
原因:所有的移動(dòng)設(shè)備都有一個(gè)viewport(視窗),這個(gè)視窗不是手機(jī)屏幕大小,而是一個(gè)虛擬的窗口,比如iPhone4的viewport寬度為980px(如下圖所示)。顯示的時(shí)候再按照比例將這980px的內(nèi)容壓縮顯示到實(shí)際的屏幕寬度中。

所以為防止讓頁(yè)面縮小,在移動(dòng)設(shè)備中,我們會(huì)做如下設(shè)置
設(shè)置結(jié)束之后,如何具體開發(fā)? 方法1.寬度盡量自適應(yīng),而不要用定寬。 方法2.用媒體查詢 @media
@media screen and (max-width: 320px) {
  //最大寬度為320px,即視窗寬度小于等于320px
  div{..}
  .class-name{...}
}

@media screen and (min-width: 320px) and (max-width: 769px){
  //最小寬度為320px,最大寬度為769px,即視窗寬度大于320px,小于769px
}
頁(yè)面優(yōu)化 目的

減少卡頓
利于SEO
便于代碼維護(hù)

方法 1. 減少頁(yè)面請(qǐng)求 減少css文件請(qǐng)求

(1)多個(gè)css文件合并成一個(gè)
(2)少量css樣式內(nèi)聯(lián)
(3)避免用import的方式引入css文件,因?yàn)槊總€(gè)import語(yǔ)句都會(huì)產(chǎn)生一個(gè)css請(qǐng)求,并且是同步的請(qǐng)求。

2.減少資源文件大小

(1)減少圖片大小
選擇合適的圖片格式,小尺寸、半透明的用png,大尺寸、色彩絢麗用jpg(因?yàn)閖pg會(huì)對(duì)圖片進(jìn)行壓縮)
壓縮圖片

(2)css值縮寫
margin,padding,border,font,border-radius等屬性

(3)省略值為0 的單位

margin: 0 10px;
line-height: .5;
background-position: 50% 0;

(4)顏色值最短表示

red
rgb(0,0,0)
rgba(0,0,0,0)
#000000
#000

(5)css選擇器合并

.left, .right {...}

(6)文件壓縮
用工具對(duì)文件進(jìn)行自動(dòng)壓縮,去掉空格。

3.提升頁(yè)面性能 加載順序

css通常放在head中,而js通常放在body底部,因?yàn)閖s會(huì)阻礙其他資源加載。

減少標(biāo)簽數(shù)量。 選擇器長(zhǎng)度
body .menu ul li a { ... } //太長(zhǎng)了
.menu a { ... } //更好
避免耗性能屬性

比如:

expression
filter
border-radius
box-shadow
gradients
給圖片設(shè)置固定寬高,并且圖片實(shí)際寬高與設(shè)置寬高相同,否則瀏覽器會(huì)回流設(shè)置多次寬高 所有表現(xiàn)用css實(shí)現(xiàn) 4.通過規(guī)范提高代碼可讀性,可維護(hù)性

(1)規(guī)范:縮進(jìn),變量名等
(2)語(yǔ)義化:除了標(biāo)簽,css、id名最好也盡量有意義
(3)盡量避免Hack,一定要用也要統(tǒng)一的標(biāo)識(shí),比如IE7用*
(4)模塊化:相關(guān)聯(lián)的結(jié)構(gòu)做成一個(gè)個(gè)模塊,復(fù)用性更強(qiáng)
(5)添加注釋

規(guī)范與模塊化 規(guī)范

1.注釋的文字兩側(cè)需加空格,防止因編碼問題導(dǎo)致注釋失效

2.為避免命名污染,可以給class加前綴,比如:

g- 布局命名
m- 模塊命名

3.語(yǔ)義化命名

//結(jié)構(gòu)化命名
top { ... }

//改用語(yǔ)義化命名
nav { ... }

4.屬性的書寫順序

模塊化 什么是模塊化

一系列相關(guān)聯(lián)的結(jié)構(gòu)組成的整體

帶有一定的語(yǔ)義,而非表現(xiàn)

比如,翻頁(yè)器(或叫分頁(yè)器paging)、輪播圖。

怎么做?

為模塊分類命名(如.m-, .md-)

以一個(gè)主選擇器開頭(模塊根節(jié)點(diǎn))

使用以主選擇器開頭的后代選擇器(模塊子節(jié)點(diǎn))

//根節(jié)點(diǎn)
.m-nav { ... }
//子節(jié)點(diǎn)
.m-nav ul{ ... }
.m-nav li{ ... }
.m-nav a{ ... }
.m-nav .z-crt a{ ... }/* 交互狀態(tài)變化 */

若有一個(gè)模塊只是比上述模塊多了一個(gè)按鈕,其余部分完全相同,怎么辦?

怎樣擴(kuò)展?

為根節(jié)點(diǎn)加一個(gè)class就好了,這里我們加一個(gè) m-nav-1。

//變化的部分在 .m-nav-1 這個(gè)新class中寫
.m-nav-1 { ... }
.m-nav-1 a{ ... }
.m-nav-1 .btn{ ... }
網(wǎng)易的規(guī)范和代碼庫(kù)

規(guī)范頁(yè):包含了CSS規(guī)范、HTML規(guī)范和工程師規(guī)范

代碼庫(kù):包含了常用的布局方式、常見模塊和元件的實(shí)現(xiàn)以及一些bug、技巧等

——————
教是最好的學(xué)。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/50687.html

相關(guān)文章

  • 頁(yè)面架構(gòu)HTML+CSS (o???)? 常用居中&amp;多列布局

    CSS Reset 1.作用 (1)清除瀏覽器默認(rèn)樣式(2)全局樣式定義 2.特別注意 (1)項(xiàng)目開發(fā)初期就定義好(2)reset.css 在引入的時(shí)候一定要放在第一位(3)不同的產(chǎn)品reset.css不一樣 3.table合并邊框間距 table { border-collapse: collapse; // 合并邊框 border-spacing: 0; //邊框間距。當(dāng) `borde...

    NervosNetwork 評(píng)論0 收藏0
  • JavaScript DOM編程基礎(chǔ)(DOM屬性&amp;事件[叮:事件代理],Ajax,BOM,f

    摘要:推薦事件事件流事件流就是事件處理執(zhí)行的過程。事件注冊(cè)事件類型事件處理函數(shù)是否在捕獲階段觸發(fā)。這個(gè)就是事件對(duì)象第二行的就是事件對(duì)象。除了阻止事件傳遞到父節(jié)點(diǎn),還阻止了當(dāng)前節(jié)點(diǎn)的后續(xù)事件。缺陷流量代價(jià),安全性問題,大小限制。 文檔樹 DOM:Document Object Model 即:用對(duì)象的形式表示HTML、CSS。 DOM包含: DOM Core DOM HTML DOM Sty...

    peixn 評(píng)論0 收藏0
  • CSS元素垂直居中【內(nèi)含vertical-align 與 line-height 屬性詳解】

    摘要:所以文字最終可以在整個(gè)中垂直居中顯示。默認(rèn)值為,即把元素放在父元素的基線上。萬(wàn)萬(wàn)沒想到用兩行代碼就實(shí)現(xiàn)了只要給容器加上下面兩條樣式,就成功垂直居中了,都是多余了的。 請(qǐng)一定看到最后,flex太令人驚喜! ヾ(o???)? 入個(gè)門 先來考慮這樣一個(gè)問題:一行文字在一個(gè)固定高度的父div中怎樣做到垂直居中?我們都知道設(shè)置父div的line-height 等于它的height就可以了,像下面...

    frontoldman 評(píng)論0 收藏0
  • CSS元素垂直居中【內(nèi)含vertical-align 與 line-height 屬性詳解】

    摘要:所以文字最終可以在整個(gè)中垂直居中顯示。默認(rèn)值為,即把元素放在父元素的基線上。萬(wàn)萬(wàn)沒想到用兩行代碼就實(shí)現(xiàn)了只要給容器加上下面兩條樣式,就成功垂直居中了,都是多余了的。 請(qǐng)一定看到最后,flex太令人驚喜! ヾ(o???)? 入個(gè)門 先來考慮這樣一個(gè)問題:一行文字在一個(gè)固定高度的父div中怎樣做到垂直居中?我們都知道設(shè)置父div的line-height 等于它的height就可以了,像下面...

    Sanchi 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

dingding199389

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<