web-css-文本

来源:https://www.cnblogs.com/FriedPotatoes/archive/2020/01/06/12153252.html
-Advertisement-
Play Games

一、文本的水平對齊方式 使用text align來設置文本的對齊方式;text align的取值:left(向左對齊)/center(水平居中對齊)/right(向右對齊)/justify(兩端對齊); text align只對應用此樣式的元素的非塊級子元素有效,對塊級子元素無效;對比使用margi ...


一、文本的水平對齊方式
    使用text-align來設置文本的對齊方式;text-align的取值:left(向左對齊)/center(水平居中對齊)/right(向右對齊)/justify(兩端對齊);
    text-align只對應用此樣式的元素的非塊級子元素有效,對塊級子元素無效;對比使用margin進行設置居中對齊,不同點是margin的作用效果對象是當前塊級元素,而並非子元素;
    ps:line-height(行高),如果行高的設置值大於font-size(字體大小)的設置值,則一行中的文字將在該行的設置的行高區域中垂直居中顯示,這個是作用到應用了該樣式的元素的區域里的每一行;
二、定位
    1.普通流定位,這也是瀏覽器預設的文檔流定位;
    2.浮動定位;
    3.相對定位:relative(相對於該元素原始位置產生的偏移距離,不會脫離文檔流);
    4.絕對定位:absolute(會脫離文檔流,相對於離自己最近的以定位的祖先級元素髮生位置偏移,ps:只要一個元素的樣式被relative/absolute/fixed這三者的任何一個所修飾,那麼該元素就成了已定位元素);
    5.固定位:fixed(會脫離文檔流);
(1)普通流定位:每個元素都有自己的占地空間,每個元素都是從其父元素的左上角位置開始顯示的;
(2)浮動定位float:left/right/none;
    left:元素脫離文檔流,在當前行的位置,停靠在父元素的左側或者挨著當前行中之前已經浮動的元素;
    right:元素脫離文檔流,在當前行的位置,停靠在父元素的右側或者挨著當前行中之前已經浮動的元素;
    none:預設值,不浮動;
發生浮動現象時的特點:
    *****預設自動補位到當前行的最後一行;
    *****元素一旦發生浮動,該元素則脫離文檔流(即該元素不占文檔流的空間,浮動之前的該元素的後面的元素會自動向該元素方向補位,補位的實質原因還是因為前面的元素脫離了文檔流)
    *****發生浮動的元素會自動變成塊級元素(變成塊級元素的實質原因實際上是該元素脫離了文檔流);
    *****沒有發生浮動的文本,行內元素,行內塊元素,不會被壓在已浮動元素的下麵,而是自己環繞著已浮動元素的周圍;
    清除浮動帶來的影響:clear:left(清除左浮動帶來的向前補位的影響)/right(清除右浮動帶來的向前補位的影響)/both(同時清除右浮動和左浮動帶來的向前補位的影響)/none;這裡並不是說clear是清除了浮動,而是清除當前元素因為前一個元素脫離文檔流而導致自己向前補位的這一個影響;
    高度坍塌:當塊級元素沒有設置高度的時候,則此時該塊級元素的高度是由該塊級元素裡面的元素內容撐起來的,但是因為該塊級元素內部的元素都已經發生浮動了,意味著裡面的子元素都已經脫離文檔流,那麼作為父級的塊元素就認為自己內部已經沒有子元素的,此時原本是由子元素的內容撐起來的高度因為子元素髮生浮動脫離文檔流的影響而導致塊級父元素的高度直接變為0;由此就發生了高度坍塌現象;
    解決:在父級塊級元素的內容末尾添加一個空的div塊級元素,同時設置該塊級元素的css樣式為清除受浮動影響的效果,這樣一來,該div塊級元素就不會因為它之前的元素髮生浮動而導致自己會自動向前補位了,這樣就保證了父級塊級元素的高度依舊是之前由內容撐起來的高度,也就不會產生高度坍塌現象了;
    這裡可以利用css樣式來添加空的div塊級元素,代碼如下:
       .list::after{
          display:block;/*以塊級元素的方式顯示*/
          content:"";/*該元素里的內容為空,沒有內容*/
          clear:both;/*清除該元素受浮動效果的影響*/
       }
    堆疊順序:只有已定位元素能設置z-index(元素的疊放順序);z-index設置的值越高的那個已定位元素,則那個元素顯示疊放在最頂層,父子級關係產生的堆疊現象設置z-index無效;

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 函數聲明和函數表達式的區別 多用函數表達式 var ff=function(){}; //函數聲明 // // if(true){ // function f1() { // console.log("哈哈,我又變帥了"); // } // }else{ // function f1() { // ...
  • 逆推繼承看原型 function F1(age) { this.age = age; } function F2(age) { this.age = age; } F2.prototype = new F1(10); function F3(age) { this.age = age; } F3.p ...
  • 總結繼承 面向對象特性: 封裝, 繼承,多態 繼承, 類與類之間的關係, 面向對象的語言的繼承是為了多態服務的 js不是面向對象的語言, 但是可以模擬面向對象,模擬繼承,為了節省記憶體 繼承: 原型作用: 數據共用, 目的是: 為了節省記憶體空間, 原型作用: 繼承 目的是:為了節省記憶體空間 原型繼承: ...
  • 拷貝繼承:把一個對象中的屬性或者方法直接複製到另一個對象中 淺拷貝 function Person() { } Person.prototype.age = 10; Person.prototype.sex = "男"; Person.prototype.height = 100; Person.p ...
  • 註釋單行註釋:// 快捷鍵: CTRL + / 多行註釋: /* 內容 */ 快捷鍵: ctrl + shift + /變數申明變數var name;賦值name = 'peach';初始化變數var age=18;更新變數var age_age = 18; age_age=20; // 更新申明多... ...
  • 創建canvas <canvas id="myCanvas" class="canvas"> 您的瀏覽器不支持canvas </canvas> 基礎設置 <script type="text/javascript"> var canvas = document.getElementById('myC ...
  • JSONP Hijackin的中文意思是JSON劫持,而能產生JSON數據劫持的原因在於前端被跨站攻擊了。跨站=跨域,跨域從字面上理解的話,就是指超出了範圍、領域。繼續追問一下,那超出了什麼範圍?原來指的範圍有多大?理解跨站攻擊的基礎在於理解這個域有多大。為了更準確的理解JSON Hijackin攻 ...
  • web前端工程師是近幾年的新興職業,也是目前火爆而且高薪的職業。不同的公司也有不同的叫法,比如:網頁界面開發,網站設計等,要學好web前端開發,需要掌握什麼方法與技巧? 一、div和table 這個是最簡單的,也是最基礎的。要熟練掌握div、form table、ul li 、p、span、font ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...