摘要:注全文摘自介紹布局頁面布局技術(shù)允許我們拾取網(wǎng)頁中的元素,并且控制它們相對正常布局流周邊元素父容器或者主視口窗口的位置。添加此代碼將給出以下結(jié)果絕對定位絕對定位絕對定位用于將元素移動到頁面的任何位置,以創(chuàng)建復(fù)雜的布局。
注:全文摘自MDN-介紹CSS布局
CSS頁面布局技術(shù)允許我們拾取網(wǎng)頁中的元素,并且控制它們相對正常布局流、周邊元素、父容器或者主視口/窗口的位置。在這個(gè)模塊中將涉及更多關(guān)于頁面布局技術(shù)的細(xì)節(jié):
每種技術(shù)都有它們的用途,各有優(yōu)缺點(diǎn)。
正常布局流是指在不對頁面進(jìn)行任何布局控制時(shí),瀏覽器默認(rèn)的HTML布局方式。讓我們快速地看一個(gè)HTML的例子:
I love my cat.
- Buy cat food
- Exercise
- Cheer up friend
The end!
默認(rèn)情況下,瀏覽器的顯示如下:
注意,HTML元素完全按照源碼中出現(xiàn)的先后次序顯示——第一個(gè)段落、無序列表、第二個(gè)段落。
布局技術(shù)會覆蓋默認(rèn)的布局行為:
position
屬性 — 正常布局流中,默認(rèn)為 static
,使用其它值會引起元素不同的布局方式,例如將元素固定到瀏覽器視口的左上角。float
值,諸如 left
能夠讓塊級元素互相并排成一行,而不是一個(gè)堆疊在另一個(gè)上面。display
屬性——標(biāo)準(zhǔn)值 block
, inline
or inline-block
會改變元素在正常布局流中的行為方式(見 Types of CSS boxes ),而一些不常見或特殊的值允許我們使用完全不同的方式進(jìn)行布局,使用工具比如Flexbox。浮動技術(shù)允許元素浮動到另外一個(gè)元素的左側(cè)或右側(cè),而不是默認(rèn)的一個(gè)堆疊另一個(gè)。float 的主要用途是布置出多個(gè)列并且浮動文字以環(huán)繞圖片。下面我們快速瀏覽一下 float
屬性并通過一個(gè)例子來說明。
float 屬性有四個(gè)可能的值:
left
— 將元素浮動到左側(cè)。right
— 將元素浮動到右側(cè)。none
— 默認(rèn)值, 不浮動。下面展示了如何用浮動來創(chuàng)建一個(gè)簡單的兩列布局。首先看一下HTML:
2 column layout example
First column
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla luctus aliquam dolor, eu lacinia lorem placerat vulputate.
Second column
Nam vulputate diam nec tempor bibendum. Donec luctus augue eget malesuada ultrices. Phasellus turpis est, posuere sit amet dapibus ut.
代碼中有一個(gè)一級標(biāo)題和兩個(gè)簡單的 下面讓我們將兩個(gè) 修改過的代碼如下: 定位技術(shù)(position)允許我們將一個(gè)元素從它在頁面的原始位置準(zhǔn)確地移動到另外一個(gè)位置。 有四種主要的定位類型需要我們了解: 我們將展示一些示例代碼來熟悉這些布局技術(shù). 這些示例代碼都作用在相同的HTML上: I am a basic block level element. I am a basic block level element. I am a basic block level element. 該HTML將使用以下CSS默認(rèn)樣式: 渲染效果如下: 相對定位通常用來對布局進(jìn)行微調(diào),比如將一個(gè)圖標(biāo)往下調(diào)一點(diǎn),以便放置文字. 我們可以通過下面的規(guī)則添加相對定位來實(shí)現(xiàn)效果: 這里我們給中間段落一個(gè) 添加此代碼將給出以下結(jié)果: 絕對定位用于將元素移動到web頁面的任何位置,以創(chuàng)建復(fù)雜的布局。有趣的是,它經(jīng)常被用于與相對定位和浮動的協(xié)同工作。 回到我們最初的非定位示例,我們可以添加以下的CSS規(guī)則來實(shí)現(xiàn)絕對定位: 這里我們給我們的中間段一個(gè) 這和之前截然不同!定位元素現(xiàn)在已經(jīng)與頁面布局的其余部分完全分離,并位于頁面的頂部。其他兩段現(xiàn)在靠在一起,好像之前那個(gè)中間段落不存在一樣。 我們現(xiàn)在暫時(shí)不討論固定定位( fixed positioning )——它基本上以相同的方式工作,除了它仍然固定在瀏覽器窗口的邊緣,而不是它定位的父節(jié)點(diǎn)的邊緣。 HTML表格對于顯示表格數(shù)據(jù)是很好的,但是很多年前——在瀏覽器中支持基本的CSS之前——web開發(fā)人員過去也常常使用表格來完成整個(gè)網(wǎng)頁布局——將它們的頁眉、頁腳、不同的列等等放在不同的表行和列中。這在當(dāng)時(shí)是有效的,但它有很多問題——表布局是不靈活的,非常重的標(biāo)記,難以調(diào)試和語義上的錯(cuò)誤(比如,屏幕閱讀器用戶在導(dǎo)航表布局方面有問題)。 CSS表格的存在是為了讓您能夠像表格一樣布局元素,而不需要上面描述的任何問題——這聽起來可能有些奇怪,您應(yīng)該使用表格元素作為表格數(shù)據(jù),但有時(shí)這可能是有用的。例如,您可能想要列出一個(gè)表單,其中有標(biāo)簽和文本輸入;這可能很棘手,但是CSS表使其變得容易。 讓我們來看一個(gè)例子。首先,創(chuàng)建HTML表單的一些簡單標(biāo)記。每個(gè)輸入元素都有一個(gè)標(biāo)簽,我們還在一個(gè)段落中包含了一個(gè)標(biāo)題。為了進(jìn)行布局,每個(gè)標(biāo)簽/輸入對都封裝在 現(xiàn)在,我們例子中的CSS。除了使用 你會注意到標(biāo)題段落已經(jīng)給出了 結(jié)果如下: CSS是一種功能強(qiáng)大的語言,它可以做很多事情,但它卻在布局上有所下降。傳統(tǒng)的老式布局方法,如 上面的例子幾乎不可能通過常規(guī)的CSS實(shí)現(xiàn)——柔性盒子(或flexbox)是為了讓這些東西更容易實(shí)現(xiàn)而被發(fā)明的。 讓我們來看一個(gè)例子;首先,一些簡單的HTML: 這里我們有一個(gè) 使用Flexbox替代它: 這個(gè)CSS的兩行非常有趣: 為了進(jìn)一步說明這是多么的神奇,我們還將添加一些JavaScript,以便您可以通過按下_Create box_按鈕來添加進(jìn)一步的子 這是一個(gè)例子——多試試見證Flexbox作為一個(gè)布局工具的強(qiáng)大。 這里提到的最具實(shí)驗(yàn)性的特性是CSS網(wǎng)格,它在瀏覽器中還沒有得到廣泛的支持。Web頁面通常使用網(wǎng)格系統(tǒng)布局,與打印媒體相同,這里的想法是通過定義一個(gè)網(wǎng)格來簡化這個(gè)過程,然后定義內(nèi)容的哪些部分位于網(wǎng)格的每個(gè)區(qū)域。 目前的CSS網(wǎng)格在任何地方都還沒有得到真正的支持(除了Firefox和Chrome的實(shí)驗(yàn)性版本)。 注意:為了更好地了解當(dāng)前的網(wǎng)格框架和其他正在使用的技術(shù),以及即將到來的原生CSS網(wǎng)格規(guī)范,請參閱我們的 Grids 文章。 【end】 文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。 轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/2181.html 摘要:學(xué)習(xí)摘要定位學(xué)習(xí)摘要定位注全文摘自定位定位允許您從正常的文檔流布局中取出元素,并使它們具有不同的行為,例如放在另一個(gè)元素的上面,或者始終保持在瀏覽器視窗內(nèi)的同一位置。使用上述四個(gè)屬性來精確指定要將定位元素移動到的位置。CSS學(xué)習(xí)摘要-定位
注:全文摘自MDN-CSS定位
定位允許您從正常的文檔流布局中取出元素,并使它們具有不同的行為,例如放在另一個(gè)元素的上面,或者始終保持在瀏覽器視窗內(nèi)的同一... 摘要:你也可以單獨(dú)設(shè)置某一個(gè)邊的三個(gè)不同屬性,如,等。屬性設(shè)置與元素相關(guān)聯(lián)的盒子模型的左外邊距。首先是我們的代碼然后是代碼上述代碼產(chǎn)生以下結(jié)果輪廓輪廓最后,還有重要的一點(diǎn),一個(gè)框的是一個(gè)看起來像是邊界但又不屬于框模型的東西。注:全文摘要自網(wǎng)絡(luò)開發(fā)者網(wǎng)站,當(dāng)然間隔也會整理一些思路和格式排版添加進(jìn)去。
CSS框模型(譯者注:也被稱為盒模型)是網(wǎng)頁布局的基礎(chǔ) ——每個(gè)元素被表示為一個(gè)矩形的方框,框的內(nèi)容... 摘要:為了實(shí)現(xiàn)這個(gè)效果,我們需要清除浮動。元素被向下移動用于清除之前的左右浮動。塊格式化上下文對浮動定位與清除浮動都很重要。浮動定位和清除浮動時(shí)只會應(yīng)用于同一個(gè)內(nèi)的元素。且為了不影響接下來的文檔標(biāo)準(zhǔn)流,往往也要收尾做出清除浮動。以下從浮動到BFC的段落 摘自MDN 網(wǎng)絡(luò)開發(fā)者float 浮動float CSS屬性指定一個(gè)元素應(yīng)沿其容器的左側(cè)或右側(cè)放置,允許文本和內(nèi)聯(lián)元素環(huán)繞它。該元素從網(wǎng)頁的正常流... 摘要:常用模式片段之摘要第一次看到這個(gè)字眼是在中,即。之后也見到一些別人的代碼里有,它和頁面的有什么關(guān)系,以及和有何淵源。以前都見過這些詞,但都似懂非懂,今天查了些資料收集了些代碼,做個(gè)完整的理解。
CSS篇
常用模式片段之CSS布局篇
http://jsorz.cn/blog/2016/08/code-patterns-of-css-layout.html
摘要:position 拉伸性質(zhì)... 摘要:常用模式片段之摘要第一次看到這個(gè)字眼是在中,即。之后也見到一些別人的代碼里有,它和頁面的有什么關(guān)系,以及和有何淵源。以前都見過這些詞,但都似懂非懂,今天查了些資料收集了些代碼,做個(gè)完整的理解。
CSS篇
常用模式片段之CSS布局篇
http://jsorz.cn/blog/2016/08/code-patterns-of-css-layout.html
摘要:position 拉伸性質(zhì)... 閱讀 3781·2021-11-23 09:51 閱讀 4417·2021-11-15 11:37 閱讀 3530·2021-09-02 15:21 閱讀 2754·2021-09-01 10:31 閱讀 886·2021-08-31 14:19 閱讀 861·2021-08-11 11:20 閱讀 3315·2021-07-30 15:30 閱讀 1696·2019-08-30 15:54整列浮動
left
,另外一個(gè)浮動為 right
。這意味著它們其中一個(gè)往左靠,另外一個(gè)往右靠。給這兩個(gè)元素分別設(shè)置 width
值,使得它們能夠在同一行放下來,并且設(shè)置一個(gè)水平的間距(總寬度不要大于100!).
div:nth-of-type(1) {
width: 48%;
float: left;
}
div:nth-of-type(2) {
width: 48%;
float: right;
}
定位技術(shù)
元素邊緣固定,或者相對于離元素最近的被定位的祖先元素(ancestor element)。絕對定位在創(chuàng)建復(fù)雜布局效果時(shí)非常有用,例如通過標(biāo)簽顯示和隱藏的內(nèi)容面板或者通過按鈕控制滑動到屏幕中的信息面板.
簡單定位示例
Positioning
body {
width: 500px;
margin: 0 auto;
}
p {
background: aqua;
border: 3px solid blue;
padding: 10px;
margin: 10px;
}
span {
background: red;
border: 1px solid black;
}
相對定位
.positioned {
position: relative;
background: yellow;
top: 30px;
left: 30px;
}
position``relative
值——這屬性本身不做任何事情,所以我們還添加了top
和left
屬性。這些可以將受影響的元素向下向右移——這可能看起來和你所期待的相反,但你需要把它看成是左邊和頂部的元素被“推開”一定距離,這就導(dǎo)致了它的向下向右移動。絕對定位
.positioned {
position: absolute;
background: yellow;
top: 30px;
left: 30px;
}
position
的 absolute
值,并且和前面一樣加上 top
和left
屬性。但是,添加此代碼將給出以下結(jié)果:top
和left
屬性對絕對位置元素的影響不同于相對位置元素。在這種情況下,他們沒有指定元素相對于原始位置的移動程度。相反,它們指定元素應(yīng)該從頁面邊界的頂部和左邊的距離(確切地說,是 元素的距離)。
CSS 表格
display
屬性外,大多數(shù)CSS都是相當(dāng)普通的。 ,
和
被告知要分別顯示表、表行和表單元——基本上,它們會像HTML表格標(biāo)記一樣,導(dǎo)致標(biāo)簽和輸入在默認(rèn)情況下排列整齊。我們所要做的就是添加一些大小、邊緣等等,讓一切看起來都好一點(diǎn),我們就完成了。
display: table-caption;
——這使得它看起來就像一個(gè)表格
——和caption-side: bottom;
讓標(biāo)題在表格的底部下進(jìn)行設(shè)計(jì),即使標(biāo)記是在源的輸入之前。這就能讓你有一點(diǎn)靈活的彈性。html {
font-family: sans-serif;
}
form {
display: table;
margin: 0 auto;
}
form div {
display: table-row;
}
form label, form input {
display: table-cell;
margin-bottom: 10px;
}
form label {
width: 200px;
padding-right: 5%;
text-align: right;
}
form input {
width: 300px;
}
form p {
display: table-caption;
caption-side: bottom;
width: 300px;
color: #999;
font-style: italic;
}
柔性盒子
float
和positioning
工作,但有時(shí)它們會感覺比他們需要的更復(fù)雜、更靈活、更有彈性。例如,如果你想要:
line-height
將會失效)。元素,里面有三個(gè)
html {
font-family: sans-serif;
}
section {
width: 93%;
height: 240px;
margin: 20px auto;
background: purple;
display: flex;
}
div {
color: white;
background: orange;
flex: 1;
margin-right: 10px;
text-shadow: 1px 1px 1px black;
}
div:last-child {
margin-right: 0;
}
section, div {
border: 5px solid rgba(0,0,0,0.85);
padding: 10px;
}
display: flex;
告訴元素的子元素作為flexible boxes——默認(rèn)情況下,它們都將展開以填充父類的可用高度,不管它是什么,并將其列出來——有足夠的寬度來包裝他們的內(nèi)容。
flex: 1;
告訴每個(gè)var section = document.querySelector("section");
var createBtn = document.querySelector(".create");
var resetBtn = document.querySelector(".reset");
function createBox() {
var box = document.createElement("div");
box.textContent = "This is a box";
section.appendChild(box);
}
createBtn.onclick = createBox;
resetBtn.onclick = function() {
while (section.firstChild) {
section.removeChild(section.firstChild);
}
createBox();
createBox();
createBox();
}
網(wǎng)格布局
IE和Edge支持一種更舊的、過時(shí)的技術(shù)。這是我們將來可以期待的!相關(guān)文章
CSS學(xué)習(xí)摘要-定位
CSS學(xué)習(xí)摘要-盒子模型
CSS學(xué)習(xí)摘要-浮動與清除浮動
JS / CSS 常用實(shí)戰(zhàn)代碼片段
JS / CSS 常用實(shí)戰(zhàn)代碼片段
發(fā)表評論
0條評論
bigdevil_s
男|高級講師
TA的文章
閱讀更多
1
關(guān)于安裝wireshark中npcap一直無法安裝以及winpcap無法安裝解決方法
工資低?裸辭?項(xiàng)目黃?走了多少彎路只有我自己知道!
Zoom 公布其“1 億美元發(fā)展基金”的首輪投資名單
酷銳云:周年慶第二波,新上香港、美國GIA直連線路特價(jià)套餐,限量20臺
HOSTMEM ,$10/年, 1核/512M內(nèi)存/10GB SSD/500GB流量/1G帶寬
傲游主機(jī):美國CN2/香港CN2/德國CN2/荷蘭CN2/香港高防VPS全場8折
一個(gè)圖片偶爾加載不出來的事故