摘要:在前端開發(fā)中,我經(jīng)常碰到一些不能馬上理解的屬性,于是打算以后但凡碰到這些微妙又模糊的屬性,都?xì)w納到這里。如圖看過有關(guān)相關(guān)博客收集在這里個(gè)人覺得第一篇最好立方體旋轉(zhuǎn)鼠標(biāo)鍵盤可控旋轉(zhuǎn)方向理解與曖昧關(guān)系好吧,變換,不過如此的屬性
在前端開發(fā)中,我經(jīng)常碰到一些不能馬上理解的css屬性, 于是打算以后但凡碰到這些微妙又模糊的屬性,都?xì)w納到這里。
CSS打印頁面中的 orphans和widows@media print打印頁面用得較少,對(duì)于打印頁面中的屬性一直比較陌生, orphans與widows(注意不是windows)屬性主要用來控制打印頁面中排版中保留的最少行問題,理解該屬性,也更能體會(huì)到CSS在排版上對(duì)于各種頁面輸出的靈活控制。
比如在打印頁面排版的時(shí)候, 某些段落在分頁的情況下會(huì)不得不出現(xiàn)截?cái)啵?b>orphans的作用就是控制出現(xiàn)截?cái)鄷r(shí)在前一頁中需要保留最少行數(shù)(在分欄情況下也會(huì)出現(xiàn)截?cái)啵┮话愕奈淖痔幚砥髟谶@種情況下會(huì)為某個(gè)出現(xiàn)截?cái)嗟亩温浔A?行(因?yàn)槿绻麤]有這項(xiàng)機(jī)制,將出現(xiàn)只有一行出現(xiàn)在截?cái)嗵?,而這種排版在很多時(shí)候是影響美觀和閱讀的),這里直接用用該帖中的栗子(原帖地址?orphans)
同樣的邏輯, 在打印頁面中,段落被截?cái)嗪笤诤笠豁撁嬷谐霈F(xiàn)的截?cái)嘤?b>widows屬性控制,widows控制在后一頁中段落被截?cái)嗪蟊A舻淖钌傩袛?shù)。
CSS spec文檔中的原文:
The "orphans" property specifies the minimum number of lines in a block container that must be left at the bottom of a page. The "widows" property specifies the minimum number of lines in a block container that must be left at the top of a page. Examples of how they are used to control page breaks are given below.
文檔地址:?13.3.2 Breaks inside elements: "orphans", "widows"
如下圖中標(biāo)紅的文字就是截?cái)嗵幩A舻淖钌傩袛?shù),改段落的orphans屬性設(shè)置為3:
代碼為:
@media print { p { orphans: 3; } }
這兩個(gè)屬性的默認(rèn)值(default)是2。
這兩個(gè)屬性僅適用于打印頁面, 貌似在常規(guī)的屏幕頁面中似乎我還不知道關(guān)于段落截?cái)嗫刂频姆椒ǎ?考慮到屏幕頁面中的情況太復(fù)雜了, 所以大多數(shù)情況也應(yīng)該交給瀏覽器來處理。
關(guān)于這兩個(gè)屬性的更多參考,mark在此:
MDN orphans
Wiki Widows and orphans
css3 動(dòng)畫中animation-fill-mode中的“both”屬性,無論在mdn或者w3school的文檔中對(duì)該屬性的解釋都是:
動(dòng)畫將會(huì)執(zhí)行 forwards 和 backwards 執(zhí)行的動(dòng)作
而MDN的原版文檔中對(duì)該屬性的解釋為:
The animation will follow the rules for both forwards and backwards,
thus extending the animation properties in both directions.
這樣的解釋讓人摸不著頭腦, 實(shí)踐出真知,我們還得試一下才能知道。
用demo說話:
播放次數(shù)為1,animation-fil-lmode為both時(shí)的動(dòng)畫停留狀態(tài)
播放次數(shù)為1 沒有設(shè)置animation-fill-mode時(shí)的動(dòng)畫停留狀態(tài)
附上css的代碼:
#box{ width:100px; height:100px; background:black; /* 在此設(shè)置有沒有both以及播放次數(shù)的對(duì)比 */ -webkit-animation: move 1s ease 1 alternate both; animation:move 1s ease 1 alternate both ; } @-webkit-keyframes move{ 100%{ -webkit-transform:translate3d(150px,0,0); transform:translate3d(150px,0,0); -ms-transform: translate3d(150px,0,0); } }
從demo中可知, both的屬性是與動(dòng)畫方向(animation-direction)以及動(dòng)畫播放次數(shù)(animation-iteration-count)聯(lián)系起來的,當(dāng)方向設(shè)置為alternate時(shí),次數(shù)為奇數(shù)次時(shí),動(dòng)畫的停留狀態(tài)為結(jié)束時(shí)狀態(tài)(forwards),反之偶數(shù)次時(shí)為初始狀態(tài)(backwards)
translate3d中的參數(shù)設(shè)置translate3d是我個(gè)人感覺蠻好用的位移動(dòng)畫函數(shù),好像translate在Safari中的支持并不是很好,所以現(xiàn)在做位移動(dòng)畫我一般都用translate3d。但對(duì)于該函數(shù)參數(shù)的認(rèn)識(shí)卻一直比較模糊,往往是現(xiàn)做現(xiàn)試,沒有一個(gè)清晰的認(rèn)識(shí)。
通過一些摸索, 首先可以明確的是該函數(shù)的參數(shù)是位移的增量設(shè)置(我是不會(huì)說一開始接觸css動(dòng)畫時(shí)我曾經(jīng)用過left,right這種奇蠢無比的方式來設(shè)置位置,囧rz), 設(shè)置增量的一個(gè)好處就是便于維護(hù), 對(duì)象的位置與對(duì)象的動(dòng)畫無關(guān)(當(dāng)然也就便于我們直接copy代碼,哈) 還有一個(gè)需要注意的地方就是y軸的參數(shù), 當(dāng)參數(shù)為正的時(shí)候時(shí)向下運(yùn)動(dòng)(并非我們印象中坐標(biāo)軸的正數(shù)向上)
如圖:
關(guān)于translate3d的詳細(xì)解讀,微軟的這篇博客寫得很詳細(xì),收藏下:
使用 CSS 轉(zhuǎn)換讓頁面變得更生動(dòng)
在做雪碧圖的時(shí)候有接觸過background-position屬性,用于顯示一個(gè)圖像的特定位置, 其實(shí)還有一個(gè)類似的屬性也可以實(shí)現(xiàn)該效果,就是clip屬性, 顧名思義就是圖像裁剪,但是初次接觸該屬性的時(shí)候需要注意它的參數(shù)設(shè)置,它的格式是這樣的:clip:rect(top,right,bottom,left); 按順時(shí)針方向設(shè)置,繼承了css上下左右設(shè)置的習(xí)慣, 但是要注意的是:rect的四個(gè)參數(shù)都是以矩形的上邊與左邊為參考線 也就是說假設(shè)一副圖像是300*300px的大小, 設(shè)置該屬性但不裁剪的參數(shù)是這樣的clip:rect(0 ,300px,300px,0) 因?yàn)橛疫吘嗯c底邊距的設(shè)置同樣是以“左邊”和“上邊”為參考的。
如圖:
關(guān)于這個(gè)屬性, 張鑫旭大神的文章還做了個(gè)詳細(xì)的demo,戳這里【CSS clip:rect矩形剪裁功能及一些應(yīng)用介紹】
CSS3 Transform的perspective屬性關(guān)于css 3d變換中的perspective屬性,網(wǎng)上很多文章都討論過,但很多時(shí)候越看越糊涂, 比如在張鑫旭大神的這篇博客中(好吧,CSS3 3D transform變換,不過如此?。┧麑erspective直接翻譯為視角, 并且在用詞上直接將其說成將視角大小設(shè)置為xxx 像素, 這種說法讓我一開始對(duì)該屬性產(chǎn)生不小的疑惑, 自己揣摩之后發(fā)現(xiàn)這種說法讓我產(chǎn)生了該參數(shù)是大小或者說寬高上的錯(cuò)覺, 其實(shí)該屬性所表示的是距離的值,也就是鏡頭到元素的距離, 我認(rèn)為更合適的說法應(yīng)該是“景深”,它設(shè)置的是鏡頭(或者說人眼)到元素的距離, 比方說一個(gè)正方體,它的長寬高都是100px,當(dāng)其父元素(perspective作用于后代并非元素本身)設(shè)置perspective為100px的時(shí)候,鏡頭距離該正方體距離為100px,也就是說鏡頭貼著正方體表面了(此時(shí)perspective等于正方體的長),當(dāng)perspective參數(shù)小雨100px時(shí), 鏡頭進(jìn)入正方體內(nèi)部。另一種情況假設(shè)元素是二維的,那么其translateZ屬性大于perspective時(shí),元素就在鏡頭后面了。 如此,將其理解為“景深”我覺得更為契合。
如圖:
看過有關(guān)perspective相關(guān)博客收集在這里(個(gè)人覺得第一篇最好):
【HTML5】3D立方體旋轉(zhuǎn)——鼠標(biāo)/鍵盤可控旋轉(zhuǎn)方向
理解:translate rotate 與 perspective 曖昧關(guān)系
好吧,CSS3 3D transform變換,不過如此!
CSS3 Transform的perspective屬性
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/111174.html
摘要:如何用獲取虛擬鍵盤高度前端早讀課月號(hào)早讀文章由湯谷投稿分享。大殺器和把動(dòng)畫轉(zhuǎn)換成原生動(dòng)畫初來乍到,本文搬運(yùn)自我月份在知乎發(fā)的文章。 前端面試之 CSS3 新特性 除了 HTML5 的新特性,CSS3 的新特性也是面試中經(jīng)常被問到的。 如何用 js 獲取虛擬鍵盤高度?-前端早讀課 9月7號(hào)早讀文章由@湯谷投稿分享。正文從這開始~ 這是一個(gè)存在很久的歷史問題了,對(duì)于這樣一個(gè)具有普遍性的問題...
摘要:線性漸變不過它稍稍有些復(fù)雜。在講解徑向漸變之前,我們先來看一看比較簡單的線性漸變。再來看徑向漸變好的,接下來我們來看徑向漸變。但對(duì)徑向漸變來說,顧名思議,所有色標(biāo)是排布在一條半徑上的。 border 邊框是我們美化網(wǎng)頁、增強(qiáng)樣式最常用的手段之一。例如: .text { width: 254px; height: 254px; background-co...
摘要:線性漸變不過它稍稍有些復(fù)雜。在講解徑向漸變之前,我們先來看一看比較簡單的線性漸變。再來看徑向漸變好的,接下來我們來看徑向漸變。但對(duì)徑向漸變來說,顧名思議,所有色標(biāo)是排布在一條半徑上的。 border 邊框是我們美化網(wǎng)頁、增強(qiáng)樣式最常用的手段之一。例如: .text { width: 254px; height: 254px; background-co...
閱讀 3191·2019-08-30 15:55
閱讀 2952·2019-08-30 13:46
閱讀 1455·2019-08-29 17:29
閱讀 3524·2019-08-29 11:08
閱讀 3448·2019-08-29 11:04
閱讀 1096·2019-08-28 18:20
閱讀 552·2019-08-26 13:37
閱讀 1339·2019-08-26 11:49