【北京小課堂第135期】什么是CSS sprites?margin負(fù)值在頁面布局中有哪些應(yīng)用?

大家好,我是IT修真院北京分院第23期的學(xué)員楊夢桐,一枚正直純潔善良的Web程序員。

今天給大家分享一下,修真院官網(wǎng)CSS任務(wù)7的知識(shí)點(diǎn)——如何制作CSS Sprite和任務(wù)8中的知識(shí)點(diǎn)——margin負(fù)值的應(yīng)用。

1. 背景介紹

在頁面布局中,有很多的可以應(yīng)用在頁面布局中的小技巧,這篇文章主要是關(guān)于CSS雪碧圖和margin負(fù)值的應(yīng)用。

首先總結(jié)一下雪碧圖。

CSS Sprite(雪碧圖)其實(shí)就是把網(wǎng)頁中一些背景圖片整合到一張圖片文件中,再利用CSS的“background-image”、“background-position”的組合進(jìn)行背景定位,用數(shù)字精確地定位出背景圖片的位置。

這樣一來,當(dāng)訪問該頁面時(shí),客戶端只需要向服務(wù)器請求少量的圖片,圖片越多請求次數(shù)越少,造成延遲的可能性也就越小,能有效減輕服務(wù)器的壓力,這是CSS Sprites最大的優(yōu)點(diǎn),也是其被廣泛傳播和應(yīng)用的主要原因。

目前很多的大型網(wǎng)站如淘寶等,為了保證自己的網(wǎng)頁加載速度,所以要在小圖標(biāo)的地方應(yīng)用雪碧圖。

首先,將需要拼接成雪碧圖的小圖標(biāo)從Ps中導(dǎo)出來,然后使用軟件拼接成雪碧圖。

2. 解決方案

這里推薦一個(gè)制作CSS Sprite的軟件:CSS gaga。

點(diǎn)擊圖片合成,把所有小圖標(biāo)全選中,拖入窗口,就可以合成雪碧圖,并返回一個(gè)坐標(biāo)的.txt文件。

實(shí)際在使用雪碧圖的時(shí)候,由于div內(nèi)顯示的是原點(diǎn)(0,0)位置的圖,其他圖片要移到原點(diǎn)才能顯示,所以要向坐標(biāo)軸負(fù)軸方向移動(dòng),x,y位置都是負(fù)的。

接下來是關(guān)于margin負(fù)值的應(yīng)用。

1.背景介紹

我們在CSS中都會(huì)使用margin,但將margin設(shè)置成負(fù)數(shù),那可能就不大好處理了。但是在實(shí)際的編程布局中,負(fù)margin可以在簡化代碼的同時(shí)達(dá)成理想的CSS布局效果。

2.知識(shí)剖析

以下幾點(diǎn)是需要知道的。

1. 負(fù)margin是絕對標(biāo)準(zhǔn)的CSS

2. 不脫離文檔流,不使用float的話,負(fù)margin元素是不會(huì)破壞頁面的文檔流。所以如果你使用負(fù)margin上移一個(gè)元素,所有跟隨的元素都會(huì)被上移。

3. 完全兼容:所有現(xiàn)代瀏覽器都完全支持負(fù)margin(IE6在大多數(shù)情況下也支持)。

4. 浮動(dòng)會(huì)影響負(fù)margin的使用,負(fù)margin不是你每天都用的CSS屬性,應(yīng)用時(shí)應(yīng)小心謹(jǐn)慎。

3. 編程實(shí)戰(zhàn)

如圖,就是設(shè)置負(fù)margin的效果。

子元素css代碼如下

如果是設(shè)置了負(fù)的margin-bottom,就會(huì)出現(xiàn)如下的效果,下面的元素會(huì)覆蓋上面的元素。

根據(jù)這些效果,參考https://www.w3cplus.com/css/the-definitive-guide-to-using-negative-margins.html,設(shè)置一個(gè)負(fù)二倍行高的margin-top,就可以產(chǎn)生如下的分三列效果。

除此之外,還有其他的應(yīng)用,比如文字3D效果。

設(shè)置兩個(gè)寬高相等的div包含相同的內(nèi)容,然后給第一個(gè)div設(shè)置一個(gè)比高小1到2個(gè)px的負(fù)margin-bottom,就可以達(dá)成這個(gè)效果。

html代碼

css代碼

還可以使用負(fù)margin改變子元素的居中

用藍(lán)色div包裹粉色div,藍(lán)色div絕對定位,top和left為50%,粉色div上方右方為負(fù)50%的margin,即在父元素中居中。

像這樣的三行布局也可以通過負(fù)margin實(shí)現(xiàn),為其設(shè)置等高的padding-bottom和margin-bottom,父div設(shè)置overflow:hidden;即可。



PPT鏈接

視頻鏈接

參考文獻(xiàn)

參考一:淺談 CSS Sprites 雪碧圖應(yīng)用

參考二:負(fù)margin用法權(quán)威指南

參考三:負(fù)值之美:負(fù)margin在頁面布局中的應(yīng)用

今天的分享就到這里啦,歡迎大家點(diǎn)贊、轉(zhuǎn)發(fā)、留言、拍磚~

我們下周再見!

------------------------------------------------------------------------------------------------------------------------

技能樹.IT修真院

“我們相信人人都可以成為一個(gè)工程師,現(xiàn)在開始,找個(gè)師兄,帶你入門,掌控自己學(xué)習(xí)的節(jié)奏,學(xué)習(xí)的路上不再迷茫”。

這里是技能樹.IT修真院,成千上萬的師兄在這里找到了自己的學(xué)習(xí)路線,學(xué)習(xí)透明化,成長可見化,師兄1對1免費(fèi)指導(dǎo)。快來與我一起學(xué)習(xí)吧~

我的邀請鏈接:jnshu.com/login/1/69475143

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,247評論 6 543
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,520評論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,362評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,805評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,541評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,896評論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,887評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,062評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,608評論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,356評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,555評論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,077評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,769評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,175評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,489評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,289評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,516評論 2 379

推薦閱讀更多精彩內(nèi)容