摘要:要實現(xiàn)下圖這個效果問題左上角的邊框?qū)挾葹?,字體大小為下面的文字和間距為。所有元素寬度固定,高度自適應(yīng)。這時就使用了的縮放。所以就顯示了增加藍(lán)色框的的意義,使脫離文檔流和文本流,同時占位。
要實現(xiàn)下圖這個效果:
問題左上角label的邊框?qū)挾葹?.5px,字體大小為15px;下面的文字和label間距為16px。所有元素寬度固定,高度自適應(yīng)。
解決方案html代碼
Lorem ipsumLorem ipsum dolor sit amet, consectetur adipisicing elit. Numquam accusamus ipsa voluptatem rem labore in alias officia, iste molestiae, illum ratione explicabo delectus laborum iusto. Tempore aspernatur, nesciunt excepturi eum.
CSS代碼
.parent{ width:300px; background: goldenrod; } #wrapper{ position: relative; } #label{ width: 100px; border: 1px solid black; font-size: 30px; transform: scale(.5); transform-origin: 0 0; position: absolute; top: 0; left: 0; } .content{ margin-top: 16px; }
js代碼
var label = document.getElementById("label"); var wrapper = document.getElementById("wrapper"); var labelHeight = window.getComputedStyle(label).height; wrapper.style.height = parseInt(labelHeight)/2 + "px";
## 心路歷程
首先,0.5px的邊框?qū)挾群?5px的字體大小,一般情況下,是不支持的。這時就使用了css3的縮放。且以父元素左上角為縮放原點。
#label{ width: 100px; border: 1px solid black; font-size: 30px; transform: scale(.5); transform-origin: 0 0; } .content{ margin-top: 16px; }
效果是這樣的
可以看到雖然label進行了縮放,但還占據(jù)了原來的大小的空間。
所以就顯示了增加藍(lán)色框的wrapper的意義,使label脫離文檔流和文本流,同時占位。(float并不能脫離文本流)
進一步的代碼是這樣的:
#wrapper{ border: 1px solid blue; position: relative; } #label{ width: 100px; border: 1px solid black; font-size: 30px; transform: scale(.5); transform-origin: 0 0; position: absolute; top: 0; left: 0; } .content{ border: 1px solid red; margin-top: 16px; }
效果:
哦喲~藍(lán)色框wrapper塌了,怎么占位呢?
label高度是不定的,怎么設(shè)置wrapper的高度呢?
只好用js了:
var label = document.getElementById("label"); var wrapper = document.getElementById("wrapper"); var labelHeight = window.getComputedStyle(label).height; wrapper.style.height = parseInt(labelHeight)/2 + "px";
效果:
我胡漢三又回來了~
請大神指點有沒有更好的方法~
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/112679.html
摘要:任務(wù)五一個最常見的移動端頁面完成的事情學(xué)習(xí)張鑫旭世界相關(guān)章節(jié)張鑫旭系列了解通配符選擇器性能優(yōu)化瀏覽器渲染原理學(xué)習(xí)各屬性及效果完成任務(wù)五學(xué)習(xí)編碼規(guī)范編碼規(guī)范并按照編碼規(guī)范優(yōu)化代碼完成深度思考計劃的事情找時間把前面任務(wù)的官方提供鏈接過一遍,查缺 任務(wù)五、 一個最常見的移動端頁面 完成的事情 float學(xué)習(xí) 張鑫旭《CSS世界》相關(guān)章節(jié) 張鑫旭 float系列 了解CSS通配符 &...
摘要:在中渲染樹中的每個節(jié)點即是一個渲染器或者渲染器對象。計算的樣式每個渲染器對象代表一個矩形區(qū)域通常是和一個節(jié)點的盒模型相對應(yīng)。坐標(biāo)系統(tǒng)是相對于根渲染器的。根渲染器的定位為和大小即為瀏覽器窗口的可視化部分比如。渲染器作廢其在屏幕上的矩形區(qū)域。 原文請查閱這里,略有刪減,本文采用知識共享署名 4.0 國際許可協(xié)議共享,BY Troland。 本系列持續(xù)更新中,Github 地址請查閱這里。 ...
摘要:在中渲染樹中的每個節(jié)點即是一個渲染器或者渲染器對象。計算的樣式每個渲染器對象代表一個矩形區(qū)域通常是和一個節(jié)點的盒模型相對應(yīng)。坐標(biāo)系統(tǒng)是相對于根渲染器的。根渲染器的定位為和大小即為瀏覽器窗口的可視化部分比如。渲染器作廢其在屏幕上的矩形區(qū)域。 原文請查閱這里,略有刪減,本文采用知識共享署名 4.0 國際許可協(xié)議共享,BY Troland。 本系列持續(xù)更新中,Github 地址請查閱這里。 ...
摘要:在中渲染樹中的每個節(jié)點即是一個渲染器或者渲染器對象。計算的樣式每個渲染器對象代表一個矩形區(qū)域通常是和一個節(jié)點的盒模型相對應(yīng)。坐標(biāo)系統(tǒng)是相對于根渲染器的。根渲染器的定位為和大小即為瀏覽器窗口的可視化部分比如。渲染器作廢其在屏幕上的矩形區(qū)域。 原文請查閱這里,略有刪減,本文采用知識共享署名 4.0 國際許可協(xié)議共享,BY Troland。 本系列持續(xù)更新中,Github 地址請查閱這里。 ...
摘要:包含后代選擇器包含選擇器,即加入空格用于選擇指定標(biāo)簽元素下的后輩元素。而后代選擇器是作用于所有子后代元素。后代選擇器通過空格來進行選擇,而子選擇器是通過進行選擇。 6-1 認(rèn)識CSS樣式 CSS全稱為層疊樣式表 (Cascading Style Sheets),它主要是用于定義HTML內(nèi)容在瀏覽器內(nèi)的顯示樣式,如文字大小、顏色、字體加粗等。使用CSS樣式的一個好處是通過定義某個樣式,可...
閱讀 2634·2021-11-19 09:56
閱讀 886·2021-09-24 10:25
閱讀 1654·2021-09-09 09:34
閱讀 2212·2021-09-09 09:33
閱讀 1066·2019-08-30 15:54
閱讀 552·2019-08-29 18:33
閱讀 1279·2019-08-29 17:19
閱讀 517·2019-08-29 14:19