Flexbox(伸缩布局盒) 是 CSS3 中一个新的布局模式,为了现代网络中更为复杂的网页需求而设计。
Flexbox 由 伸缩容器 和 伸缩项目 组成。通过设置元素的 display 属性为 flex 或 inline-flex 可以得到一个伸缩容器
设置为flex
的容器被渲染为一个块级元素,而设置为inline-flex
的容器则渲染为一个行内元素。
例如:此处将 类名为 flex-container 的元素设置为伸缩容器
伸缩容器中的每一个子元素都是一个伸缩项目。伸缩项目可以是任意数量的。伸缩容器外和伸缩项目内的一切元素都不受影响。
简单地说,Flexbox 定义了伸缩容器内伸缩项目该如何布局。
Flex Lines 伸缩行
伸缩项目沿着伸缩容器内的一个 伸缩行 定位。通常每个伸缩容器只有一个伸缩行。 默认伸缩行从左往右
例子:


<span style="color: #008080;"> 1</span> <span style="color: #800000;"><div class="flex-container"> <span style="color: #008080;"> 2</span> <span style="color: #800000;"><div class="flex-item">flex item 1</div> </span><span style="color: #008080;"> 3</span> <span style="color: #800000;"><div class="flex-item">flex item 2</div> </span><span style="color: #008080;"> 4</span> <span style="color: #800000;"></span> </div> </span><span style="color: #008080;"> 5</span> <span style="color: #008080;"> 6</span> <span style="color: #800000;">样式: </span><span style="color: #008080;"> 7</span> <span style="color: #008080;"> 8</span> <span style="color: #800000;">.flex-container </span>{ <span style="color: #008080;"> 9</span> <span style="color: #ff0000;">display</span>:<span style="color: #0000ff;"> -webkit-flex</span>; <span style="color: #008080;">10</span> <span style="color: #ff0000;">display</span>:<span style="color: #0000ff;"> flex</span>; <span style="color: #008080;">11</span> <span style="color: #ff0000;">width</span>:<span style="color: #0000ff;"> 300px</span>; <span style="color: #008080;">12</span> <span style="color: #ff0000;">height</span>:<span style="color: #0000ff;"> 240px</span>; <span style="color: #008080;">13</span> <span style="color: #ff0000;">background-color</span>:<span style="color: #0000ff;"> Silver</span>; <span style="color: #008080;">14</span> } <span style="color: #008080;">15</span> <span style="color: #008080;">16</span> <span style="color: #800000;">.flex-item </span>{ <span style="color: #008080;">17</span> <span style="color: #ff0000;">background-color</span>:<span style="color: #0000ff;"> DeepSkyBlue</span>; <span style="color: #008080;">18</span> <span style="color: #ff0000;">width</span>:<span style="color: #0000ff;"> 100px</span>; <span style="color: #008080;">19</span> <span style="color: #ff0000;">height</span>:<span style="color: #0000ff;"> 100px</span>; <span style="color: #008080;">20</span> <span style="color: #ff0000;">margin</span>:<span style="color: #0000ff;"> 5px</span>; <span style="color: #008080;">21</span> }
效果图:
再加
<div class="flex-item">flex item 3</div>
<div class="flex-item">flex item 4</div><br><br>伸缩项目的宽度超过了 伸缩容器的宽度,伸缩容器的宽度不会改变,伸缩项目的宽度减小<br><br><br><br>


<span style="color: #008080;"> 1</span> <span style="color: #800000;"><div class="flex-container"> <span style="color: #008080;"> 2</span> <span style="color: #800000;"><div class="flex-item">flex item 1</div> </span><span style="color: #008080;"> 3</span> <span style="color: #800000;"><div class="flex-item">flex item 2</div> </span><span style="color: #008080;"> 4</span> <span style="color: #800000;"></span> </div> </span><span style="color: #008080;"> 5</span> <span style="color: #008080;"> 6</span> <span style="color: #008080;"> 7</span> <span style="color: #800000;">CSS样式 </span><span style="color: #008080;"> 8</span> <span style="color: #800000;">.flex-container </span>{ <span style="color: #008080;"> 9</span> <span style="color: #ff0000;"> direction</span>:<span style="color: #0000ff;"> rtl</span>; <span style="color: #008080;">10</span> <span style="color: #ff0000;"> display</span>:<span style="color: #0000ff;"> -webkit-flex</span>; <span style="color: #008080;">11</span> <span style="color: #ff0000;"> display</span>:<span style="color: #0000ff;"> flex</span>; <span style="color: #008080;">12</span> <span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 300px</span>; <span style="color: #008080;">13</span> <span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 240px</span>; <span style="color: #008080;">14</span> <span style="color: #ff0000;"> background-color</span>:<span style="color: #0000ff;"> Silver</span>; <span style="color: #008080;">15</span> <span style="color: #008080;">16</span> } <span style="color: #008080;">17</span> <span style="color: #008080;">18</span> <span style="color: #800000;">.flex-item </span>{ <span style="color: #008080;">19</span> <span style="color: #ff0000;"> background-color</span>:<span style="color: #0000ff;"> DeepSkyBlue</span>; <span style="color: #008080;">20</span> <span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 100px</span>; <span style="color: #008080;">21</span> <span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 100px</span>; <span style="color: #008080;">22</span> <span style="color: #ff0000;"> margin</span>:<span style="color: #0000ff;"> 5px</span>; <span style="color: #008080;">23</span> }
效果:
伸缩行从右往左,文字也从右往左
为了描述抽象的书写模式,Flexbox 使用 主轴 和 侧轴的概念。伸缩行跟随主轴。侧轴则垂直于主轴。
flex-direction 伸缩流的方向
默认值 row
再次提醒,默认是从左至右,从上到下。其他的值如下:
- row-reverse: 主轴起点和主轴终点交换。如果书写模式是从左至右,伸缩项目则是从左往右显示。
- column: 主轴和侧轴交换。如果书写系统是垂直的,那么伸缩项目也是垂直显示的。
- column-reverse: 和 column 一样,但是方向相反。
justify-content 主轴对齐
用于调整主轴上伸缩项目的位置。可能的值为:
- flex-start (默认)
- flex-end
- center
- space-between
- space-around
align-items 侧轴对齐
调整伸缩项目在侧轴上的定位方式。可能的值有:
- flex-start (默认)
- flex-end
- center
- baseline
- stretch
flex-wrap 伸缩行换行
为伸缩容器创建多个伸缩行。这个属性接受以下值:
- nowrap (默认)
- wrap
- wrap-reverse
align-content 堆栈伸缩行
它对齐的是伸缩行,它接受的值:
- stretch (默认)
- flex-start
- flex-end
- center
- space-between
- space-around
flex-flow 伸缩方向与换行 是flex-direction
和flex-wrap
的缩写。

HTML代碼可以通過在線驗證器、集成工具和自動化流程來確保其清潔度。 1)使用W3CMarkupValidationService在線驗證HTML代碼。 2)在VisualStudioCode中安裝並配置HTMLHint擴展進行實時驗證。 3)利用HTMLTidy在構建流程中自動驗證和清理HTML文件。

HTML、CSS和JavaScript是構建現代網頁的核心技術:1.HTML定義網頁結構,2.CSS負責網頁外觀,3.JavaScript提供網頁動態和交互性,它們共同作用,打造出用戶體驗良好的網站。

HTML的功能是定義網頁的結構和內容,其目的在於提供一種標準化的方式來展示信息。 1)HTML通過標籤和屬性組織網頁的各個部分,如標題和段落。 2)它支持內容與表現分離,提升維護效率。 3)HTML具有可擴展性,允許自定義標籤增強SEO。

HTML的未來趨勢是語義化和Web組件,CSS的未來趨勢是CSS-in-JS和CSSHoudini,JavaScript的未來趨勢是WebAssembly和Serverless。 1.HTML的語義化提高可訪問性和SEO效果,Web組件提升開發效率但需注意瀏覽器兼容性。 2.CSS-in-JS增強樣式管理靈活性但可能增大文件體積,CSSHoudini允許直接操作CSS渲染。 3.WebAssembly優化瀏覽器應用性能但學習曲線陡,Serverless簡化開發但需優化冷啟動問題。

HTML、CSS和JavaScript在Web開發中的作用分別是:1.HTML定義網頁結構,2.CSS控製網頁樣式,3.JavaScript添加動態行為。它們共同構建了現代網站的框架、美觀和交互性。

HTML的未來充滿了無限可能。 1)新功能和標準將包括更多的語義化標籤和WebComponents的普及。 2)網頁設計趨勢將繼續向響應式和無障礙設計發展。 3)性能優化將通過響應式圖片加載和延遲加載技術提升用戶體驗。

HTML、CSS和JavaScript在網頁開發中的角色分別是:HTML負責內容結構,CSS負責樣式,JavaScript負責動態行為。 1.HTML通過標籤定義網頁結構和內容,確保語義化。 2.CSS通過選擇器和屬性控製網頁樣式,使其美觀易讀。 3.JavaScript通過腳本控製網頁行為,實現動態和交互功能。

HTMLISNOTAPROGRAMMENGUAGE; ITISAMARKUMARKUPLAGUAGE.1)htmlStructures andFormatSwebContentusingtags.2)itworkswithcsssforstylingandjavascript for Interactivity,增強WebevebDevelopment。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

記事本++7.3.1
好用且免費的程式碼編輯器

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境