CSS3新特性應用之字體排印

来源:http://www.cnblogs.com/cqhaibin/archive/2016/12/19/6196195.html
-Advertisement-
Play Games

一、插入換行 ~:表示同輩元素之後指定類型的元素,如;elm1 ~ elm2表示,elm1之後的所有elm2元素,且elm1與elm2都是在同一個父級元素。 +:表示同輩元素的兄弟元素。 \A:一個空白換行符 解決方案: 在dd與dt相鄰的dt上的子元素前面加入一個空白換行符 在相鄰的dd與dd之間 ...


一、插入換行

  • ~:表示同輩元素之後指定類型的元素,如;elm1 ~ elm2表示,elm1之後的所有elm2元素,且elm1與elm2都是在同一個父級元素。
  • +:表示同輩元素的兄弟元素。
  • \A:一個空白換行符
  • 解決方案:
    • 在dd與dt相鄰的dt上的子元素前面加入一個空白換行符
    • 在相鄰的dd與dd之間,加入一個逗號
  • 示例代碼:
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        dt, dd{
            display: inline;
        }
        dd{
            font-weight: bold; 
            margin: 0px 0px 0px 5px;
        }
        dd + dt::before{
            content: '\A';
            white-space: pre; /*html預設換行符與其相鄰的其他空白符合併,pre表示不合併空白符*/
        }
        dd + dd::before{
            content: ',';
            margin-left: -5px;
        }
    </style>
</head>
<body> 
    <dt>Name</dt><dd>Sam Long</dd>  
    <dt>Email</dt><dd>[email protected]</dd><dd>[email protected]</dd> 
    <dt>Location</dt><dd>CQ</dd> 
</body>

二、文本行的斑馬條紋

  • 背景尺寸是行高的2倍
  • 註意em單位
  • white-space:設置或檢索對象內空格的處理方式
    • normal:預設處理方式
    • pre:用等寬字體顯示預格式化的文本,空白字元會被瀏覽器保留
    • nowrap:文本不會換行,直到遇到<br>標簽為止
    • pre-wrap:用等寬字體顯示預格式化的文本,空白字元會被瀏覽器保留,文本會換行
    • pre-line:保持換行符,合併空白符
  • 示例代碼:
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .wrap{  
            padding: .5em;
            line-height: 1.5;
            background: hsl(20, 50%, 95%);
            background-image: linear-gradient(
                            rgba(120,0,0,.1) 50%, transparent 0);
            background-size: auto 3em;
            background-origin: content-box;
            font-family: Consolas, Monaco, monospace;
        }
        .wrap code{
            font: inherit;
        }
    </style>
</head>
<body> 
<pre class="wrap"> <code> while(true){
    i++;
    if(i>10){
        break;
    }else{
        console.log(i);
    }
}</code></pre> 
</body>

三、調整tab的寬度

  • 註意Ide是否應用的tab替換為space的功能,必須要關閉。
  • 利用tab-size指定tab的大小
  • 示例代碼
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        pre, code{
            font-family: monospace;
        }
        pre{
            white-space: pre;
            background: red;
            tab-size: 2;
            display: block;
        }
    </style>
</head>
<body>
<pre><code>
while(true){
    var d = new Date();
}
</code></pre>
</body>

四、自定義下劃線

  • linear-gradient的角度,預設是180deg
  • text-shadow實現陰影效果,做出左右陰影偏移
  • 存在相容性問題,chrome50版本沒有下劃線顯示
  • 示例代碼:
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style> 
        body {
            font: 250%/1.6 Baskerville, Palatino, serif;
        }

        a {
            background: -webkit-linear-gradient(gray, gray) no-repeat;
            background-size: 100% 1px;
            background-position: 0 1.02em;
            text-shadow: .05em 0 white, -.05em 0 white; /*水平左、右偏移一個背景色的陰影,用於降級字母的下半處理*/
        }

        p:nth-child(2) a {
            background: -webkit-linear-gradient(180deg, gray 66%, transparent 0) repeat-x; /*0,180deg都是可以的*/
            background-size: .2em 2px;
            background-position: 0 1em;
        }
    </style>
</head>
<body>
    <p>The only way to <a>get rid of a temptation</a> is to <a>yield</a> to it.</p>
    <p>The only way to <a>get rid of a temptation</a> is to <a>yield</a> to it.</p>
</body>

五、現實中的文字效果

  • text-shadow實現的效果不能退化,如果瀏覽器不支持則看不見,可以用filter實現,但支持得更好(但可以退化樣式)
  • text-shadow設置多個值,並按遞增規則偏移,可以製作出立體效果
  • 凸版文字
    • 字體太小text-shadow屬性產生的效果不可接受
    • 示例代碼:
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        body{
            font: 110%/1.6 Baskerville, Palatino, serif; /*字體過小表現不出樣式*/
        }
        .wrap{
            width: 200px;
            background: hsl(210, 13%, 60%);
            color: hsl(210, 13%, 30%);
            padding: .1em;
            text-shadow: 0 1px 1px hsla(0, 0%, 100%, .8);
        }
        .wrap02{
            margin-top: 10px;
            width: 200px;
            background: hsl(210, 13%, 60%);
            color: hsl(210, 13%, 30%);
            padding: .1em;
            text-shadow: 0 -1px 1px hsla(0, 0%, 100%, .8);
        }
    </style>
</head>
<body>
    <div class="wrap">
        <span>根據協議,四省(市)將深化教育綜合改革合作交流.</span>
    </div>
    <div class="wrap02">
        <span>根據協議,四省(市)將深化教育綜合改革合作交流.</span>
    </div>
</body>

 

  • 其他效果示例代碼:
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .wrap{
            text-align: center;
            font-size: 38px;
            width: 200px;
            background: deeppink;
            color: white;
            text-shadow: 1px 1px black, -1px 1px black, -1px -1px black, 1px -1px black;
        }
        .wrap02{
            margin-top: 10px;
            font-size: 38px;
            width: 200px;
            text-align: center;
            background: #203;
            color: #ffc;
            transition: 1s;
        }
        .wrap02:hover{
            text-shadow: 0 0 .1em, 0 0 .3em;
            color:transparent;
        }
        .wrap03{
            margin-top: 10px;
            width: 200px; 
            font-size: 38px;
            text-align: center;
            color: white;
            background: hsl(0,50%,45%);
            text-shadow: 0 1px hsl(0, 0%, 85%),
                         0 2px hsl(0, 0%, 65%),
                         0 3px hsl(0, 0%, 45%),
                         0 4px hsl(0, 0%, 25%),
                         0 5px hsl(0, 0%, 5%),
                         0 5px 10px black;
        }
        .wrap04{
            margin-top: 10px;
            width: 200px; 
            font-size: 38px;
            text-align: center;
            color: white;
            background: hsl(0,50%,45%);
            text-shadow: 1px 1px black, 2px 2px black,
                         3px 3px black, 4px 4px black,
                         5px 5px black, 6px 6px black,
                         7px 7px black, 8px 8px black;
        }
    </style>
</head>
<body>
    <div class="wrap">
        <span>CSS</span>
    </div>
    <div class="wrap02">
        <span>CSS</span>
    </div>
    <div class="wrap03">
        <span>CSS</span>
    </div>
    <div class="wrap04">
        <span>CSS</span>
    </div>
</body>

六、自定義覆選框

  • 系統自帶覆選框美化
    • 利用css3提供的:checked偽類選擇器實現
    • 寬、高、對齊等設置單位最好用em,讓按鈕變得更為靈活
    • 示例代碼:
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        input[type="checkbox"]{
            display: none;    
        }
        input[type="checkbox"] + label::before{
            content: '\a0'; /*不換行空格*/
            display: inline-block;
            background: silver;
            border-radius: .2em;
            margin-right: .2em;
            width: .8em;
            height: .8em; 
            line-height: .65em;
            text-indent: .15em;
        }
        input[type="checkbox"]:checked + label::before{
            content: '\2713';
            background: yellowgreen;
        }
    </style>
</head>
<body>
    <input type="checkbox" id="anesome"/>
    <label for="anesome">anesome</label>
</body>
  • 開關按鈕的實現
    • 偽類選擇器 + 修飾label元素實現
    • 示例代碼:
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        input[type="checkbox"]{
            display: none;    
        }
        input[type="checkbox"] + label{ 
            display: inline-block;
            padding: .3em .5em;
            background: #ccc;
            border: 1px solid rgba(0, 0, 0, .2);
            background-image: linear-gradient(#ddd,#bbb);
            text-align: center;
            border-radius: .3em;
            box-shadow: 0 1px white inset;
            text-shadow: 0 1px 1px white;
        } 
        input[type="checkbox"]:checked + label{
            box-shadow: .05em .1em .2em rgba(0, 0, 0, .6) inset;
            border-color: rgba(0, 0, 0, .3);
            background: #bbb;
        }
    </style>
</head>
<body>
    <input type="checkbox" id="anesome"/>
    <label for="anesome">anesome</label>
</body>


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

-Advertisement-
Play Games
更多相關文章
  • 閱讀目錄 架構的定義 如何開始設計一個架構 一個好架構的特點 做架構中的誤區 結語 一、架構的定義 所謂一千個架構師中有一千種“最好的架構”模式。 “架構”是我們這行業種一個很常見的詞,表明其必然也是經歷了很長的歲月打磨所形成的一個詞。架構的這個詞出現的意義是什麼?為瞭解決什麼問題?只有把這2個問題 ...
  • 引子 前幾天看到微信後臺團隊分享了TLS相關文章,正好gRPC里TLS數據加密是很重要的一塊,於是整理出了這篇文章。 在gRPC里,如果僅僅是用來做後端微服務,可以考慮不加密。本文太長,先給個大綱。 1. HTTPS,HTTP/2介紹 2. TLS加密原理、實現庫 3. HTTP/2協議協商機制 4 ...
  • 一、Angular特點: 1、雙向數據綁定,主打賣點 2、MVVM 模型,把視圖和邏輯分開 3、依賴註入 個人感覺,在Angular中,視圖對應 HTML 模板,視圖邏輯對應directive 和 controller。 二、模塊 Angular 中通過模塊來管理命名空間,可以通過不同的模塊來隔離不 ...
  • 本文轉載自 http://www.mynawang.com/ 相關代碼可訪問 https://github.com/mynawang/Design-Pattern-Learning 什麼是設計模式 設計模式(Design pattern)是一套被反覆使用、多數人知曉的、經過分類編目的、代碼設計經驗的 ...
  • <html> ...
  • 簡介 "transformjs" 在非react領域用得風生水起,那麼react技術棧的同學能用上嗎?答案是可以的。junexie童鞋已經造了個 "react版本" 。 動畫實現方式 傳統 web 動畫的兩種方式 : 1. 純粹的CSS3 :如:transition/animation+transf ...
  • 基本上每個項目都需要用到模態框組件,由於在最近的項目中,alert組件和confirm是兩套完全不一樣的設計,所以我將他們分成了兩個組件,本文主要討論的是confirm組件的實現。 ...
  • 一、AJAX示例 AJAX全稱為“Asynchronous JavaScript And XML”(非同步JavaScript和XML) 是指一種創建互動式網頁應用的開發技術、改善用戶體驗,實現無刷新效果。 1.1、優點 不需要插件支持 優秀的用戶體驗 提高Web程式的性能 減輕伺服器和帶寬的負擔 1 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...