Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 日本一区二区三区视频在线,国产精品99久久久久久人,中文字幕一二区

          整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          前端每日實戰:苦練 CSS 基本功-圖解輔助線的原理和畫法


          用 CSS 進行繪圖和布局時,除了借助瀏覽器開發工具之外,還經常需要繪制一些輔助線,以便定位參考。今天就以第 170 號作品中使用的網格線為例,詳細講解一下輔助線的原理和畫法。

          為了使輔助線明顯可見,把線的顏色設置為和背景對比強烈的白色,并且線也粗一些,在實際使用時,你應該降低輔助線與背景的對比并且使用細線。

          分步圖解

          1、定義容器

          div {
              font-size: 50px;
              width: 6em;
              height: 4em;
              background-color: teal;
          }

          假設你有一個 <div> 容器,容器里是否有元素都可以,當前演示為了突顯輔助線,暫時讓容器里空空如也:

          2、一條基本的橫線

          div {
              background-image: linear-gradient(to bottom, transparent 95%, white 95%);
          }

          網格線是一條一條線條組成的,所以要先畫出一條線,它的95%都是透明的,只有5%是白色的:

          3、一條有尺寸的橫線

          div {
              background-size: 1em 1em;
              background-repeat: no-repeat;
          }

          我自己是一名從事了多年開發的web前端老程序員,目前辭職在做自己的web前端私人定制課程,今年年初我花了一個月整理了一份最適合2019年學習的web前端學習干貨,各種框架都有整理,送給每一位前端小伙伴,想要獲取的可以關注我的頭條號并在后臺私信我:前端,即可免費獲取。

          請把繪制網格線想象成是鋪地磚,首先要定義地磚的尺寸,這里用 1em 1em 定義了一塊方磚,同時讓磚塊不重復,所以只顯示出了孤單的一塊磚:

          4、橫向平鋪地磚

          div {
              background-repeat: repeat-x;
          }

          如果把地磚橫向平鋪,就能組合成一條水平線:

          5、縱向平鋪地磚

          div {
              background-repeat: repeat-y;
          }

          如果把地磚縱向平鋪,就能組合成一條垂直線。
          錯!
          縱向平鋪是像階梯一樣的效果:

          6、橫向和縱向同時平鋪地磚

          div {
              background-repeat: repeat;
          }

          橫向和縱向同時平鋪,就是像作業本一樣的多條橫線效果。注意,這時最頂端是沒有線的:

          7、豎線平鋪效果

          div {
              background-image: linear-gradient(to right, transparent 95%, white 95%);
              background-size: 1em 1em;
              background-repeat: repeat;
          }

          假如把地磚換成向右的豎線,即只把 to bottom 改為 to right ,其他不變,繪制出的就是一排一排的豎線。同樣注意,這時最左邊是沒有線的:

          8、不完美的網格線

          div {
              background-image:
                  linear-gradient(to bottom, transparent 95%, white 95%),
                  linear-gradient(to right, transparent 95%, white 95%);
              background-size: 1em 1em;
              background-repeat: repeat;
          }

          把第6步和第7步合并起來,網格線基本成型了,不過頂端和左端還缺少線條:

          9、一段頂端線

          div {
              background-image: 
                  linear-gradient(to top, transparent 95%, white 95%);
              background-size: 1em 1em;
              background-repeat: no-repeat;
          }

          來解決頂端線的問題,先畫出一段頂端線。這段代碼和第3步極相似,僅僅是 to bottom 改成了 to top:

          10、一條頂端線

          div {
              background-repeat: repeat-x;
          }

          把這一段頂端線水平平鋪,就是一條定位在頂部的水平線:

          11、一段左端線

          div {
              background-image: 
                  linear-gradient(to left, transparent 95%, white 95%);
              background-size: 1em 1em;
              background-repeat: no-repeat;
          }

          用類似的辦法解決左端線問題,先定義一段左端線,注意 linear-gradient 函數的第 1 個參數改成 to left 了:

          12、一條左端線

          div {
              background-repeat: repeat-y;
          }

          平鋪這段左端線,就得到了一條緊挨容器左側的豎線:

          13、All in one 的完美效果

          div:nth-child(13) {
              background-image: 
                  linear-gradient(to bottom, transparent 95%, white 95%),
                  linear-gradient(to right, transparent 95%, white 95%),
                  linear-gradient(to top, transparent 95%, w hite 95%),
                  linear-gradient(to left, transparent 95%, white 95%);
              background-size: 1em 1em;
              background-repeat: repeat, repeat, repeat-x, repeat-y;

          好了,我們把第8步不完美的網格線、頂端線、左端線都合起來,就是完美的網格線了,注意 background-repeart 的寫法,它有 4 個參數,分別對應 background-image 里的 4 條線:

          干得漂亮!收工。

          原文鏈接:https://segmentfault.com/a/1190000021507641

          作者:comehope

          SS不規則卡片,純CSS制作優惠券樣式,CSSS實現鋸齒樣式

          之前也有寫過 CSS 優惠券樣式《CSS3徑向漸變實現優惠券波浪造型》,這次再來溫習一遍,并且將更為詳細的講解,從布局到具體樣式說明,最后定義 CSS 變量,自定義主題顏色。

          布局

          布局 其實是學習前端的重要部分,最常用的方式就是從上而下、從左而右、亦或者兩個相結合。

          看上圖,而這里,我們就只是最簡單的布局方式,從上而下:

          1、優惠券金額和過期時間

          2、優惠券描述

          3、按鈕(其實按鈕也可以放到“2”里面去)

          這樣分析,我們就有了 html 架構了

          <div class="coupon">
            <!-- 1、優惠券金額和過期時間 -->
            <div class="price">
              100元
              <span>優惠券</span>
              <p class="timeout">2020-12-31 18:18:18過期</p>
            </div>
          
            <!-- 2、優惠券描述 -->
            <div class="describe">
              <p>1、商城、美食可用</p>
              <p>2、過期作廢</p>
            </div>
          
            <!-- 3、按鈕 -->
            <div class="btns">
              <button>立即使用</button>
            </div>
          </div>
          

          CSS不規則卡片,純CSS制作優惠券樣式,CSSS實現鋸齒樣式

          CSS修飾

          接下來我們用 CSS 美化我們的 html 。同理,我們也根據布局分步進行樣式書寫。

          1、優惠券金額和過期時間樣式

          這里的核心就是上方的凹槽和下方的鋸齒

          .coupon{
            background-color: #E0E0E0;
            width: 200px;
            /* css變量 */
            --main-color: #EC407A;
            --f-color: #444;
          }
          .price {
            position: relative;
            height: 120px;
            background-image: radial-gradient(
                circle at 100px -8px, #fff 20px, var(--main-color) 21px
            );
            color: #fff;
            font-size: 20px;
            text-align: center;
            padding-top: 40px;
          }
          .price .timeout{
            color: var(--f-color);
            font-size: 14px;
            margin-top: 25px;
          }
          .price span{
            font-size: 14px;
          }
          

          CSS不規則卡片,純CSS制作優惠券樣式,CSSS實現鋸齒樣式

          這里用到了 徑向漸變,不清楚用法的小伙伴可以看看語法:

          background-image: radial-gradient(shape size at position, start-color, ..., last-color);

          注釋:

          (1)、shape 確定圓的類型:

          ellipse (默認): 指定橢圓形的徑向漸變。

          circle :指定圓形的徑向漸變

          (2)、size 定義漸變的大小,可能值:

          farthest-corner (默認) : 指定徑向漸變的半徑長度為從圓心到離圓心最遠的角

          closest-side :指定徑向漸變的半徑長度為從圓心到離圓心最近的邊

          closest-corner : 指定徑向漸變的半徑長度為從圓心到離圓心最近的角

          farthest-side :指定徑向漸變的半徑長度為從圓心到離圓心最遠的邊

          (3)、position 定義漸變的位置。可能值:

          center(默認):設置中間為徑向漸變圓心的縱坐標值。

          top:設置頂部為徑向漸變圓心的縱坐標值。

          bottom:設置底部為徑向漸變圓心的縱坐標值。

          (4)、start-color, ..., last-color 用于指定漸變的起止顏色。

          這樣價格上方的凹槽就有了,接下來下方的鋸齒我們也可以用 徑向漸變 的方式實現:

          .price::after{
            position: absolute;
            content: '';
            display: block;
            bottom: 0px;
            height: 10px;
            width: 100%;
            /* background-size: 11px 200px; */
            background-image: 
              radial-gradient(
              circle at 5px 10px, 
              #E0E0E0 6px, 
              var(--main-color) 7px);
          }
          

          偽類元素 ::after 設置徑向漸變背景為一個圓,后進行平鋪就形成了鋸齒,調整位置。

          CSS不規則卡片,純CSS制作優惠券樣式,CSSS實現鋸齒樣式

          其實還有更簡單的方法,可以直接用一個虛線邊框即可搞定,請看:

          .price::after{
            position: absolute;
            content: '';
            display: block;
            bottom: -5px;
            width: 100%;
            border-bottom: 10px dotted #E0E0E0;
          }
          

          CSS不規則卡片,純CSS制作優惠券樣式,CSSS實現鋸齒樣式

          當然也有缺陷,間隔位置不好控制

          2、優惠券描述與按鈕 優惠券核心鋸齒已經搞定了,下面都是小菜啦,非常簡單咯

          .describe{
            color: #333;
            padding: 10px;
            font-size: 14px;
          }
          .btns {
            /* 使其button可以居中 */
            text-align: center;
          }
          .btns button{
            /* 重置按鈕樣式 */
            border: none;
            box-shadow: none;
            outline: none;
          
            background-color: var(--main-color);
            color: #fff;
            width: 50%;
            border-radius: 20px;
            line-height: 30px;
            margin: 40px 0 20px;
            cursor: pointer;
          }
          

          CSS不規則卡片,純CSS制作優惠券樣式,CSSS實現鋸齒樣式

          主題顏色

          大家都看到了,我們上方代碼主要顏色都采用的變量,而且變量是定義在 .coupon 類選擇器里面的。這樣的原因是:

          1、CSS變量作用域(CSS變量只能作用于自身以及后代元素。兄弟元素,祖先元素都不能享用。)

          2、方便主題使用

          ok,我們就可以copy 多個 優惠券,并給每個添加一個不同的 class,比如下方的 theme1、theme2、theme3

          <div class="coupon theme1">
            ...
          </div>
          <div class="coupon theme2">
            ...
          </div>
          <div class="coupon theme3">
            ...
          </div>
          <div class="coupon">
            ...
          </div>
          

          接下來我們就為不同主題定義不同的顏色變量

          .coupon.theme1{
            --main-color: #8E24AA;
            --f-color: #fff;
          }
          
          .coupon.theme2{
            --main-color: #039BE5;
            --f-color: #fff;
          }
          
          .coupon.theme3{
            --main-color: #26A69A;
            --f-color: #fff;
          }
          

          這樣,theme1主題下的優惠券,就是紫色主題,theme2主題下的優惠券,就是藍色主題...,而默認主題顏色就是我們 .coupon 類選擇器里面的定義的變量顏色(紅色)。

          小結

          今天你學到了嗎?從布局分析到具體實現,再到主題顏色,相信小伙伴們都各有所得。

          這里是云端源想IT,幫你輕松學IT”

          嗨~ 今天的你過得還好嗎?

          睡眠等同于希望

          每次醒來都是一個新的開始

          一個新的希望


          - 2024.03.22 -


          在Web開發的世界中,CSS(層疊樣式表)是構建視覺吸引力和定義網頁布局的不可或缺的工具。

          掌握如何恰當地引入CSS樣式以及理解它們的優先級規則,對于前端開發者來說至關重要。今天,我們就來深入探討CSS的四種引入方式,以及選擇器的優先級之謎,了解常用的CSS樣式及使用方法!



          一、CSS四種樣式引入方式

          CSS(層疊樣式表)為網頁提供了豐富的樣式定義,允許開發者通過多種方式將樣式應用到HTML文檔中。以下是四種主要的CSS引入方式:


          1.1 行內樣式

          這是最直接也最簡單的方法,通過在HTML元素的style屬性中直接編寫CSS規則。

          示例:

          <p style="color: red; font-size: 20px;">這是一段紅色的文字。</p>


          這種方式的優點是簡單快捷,但缺點是它使得HTML代碼與樣式混合,不夠純凈,且不利于樣式的復用和維護。


          1.2 內嵌樣式

          在一個HTML文檔中使用<style>標簽將CSS規則嵌入到HTML的head部分。這種方式適用于定義特定于某一頁面的樣式。

          示例:

          <head>
          <style>
          body {background-color: powderblue;}
          h1 {color: blue;}
          p {color: red;}
          </style>
          </head>
          <body>
          <h1>This is a heading</h1>
          <p>This is a paragraph.</p>
          </body>



          1.3 外部樣式

          這是最常用的方法,它通過<link>標簽將外部的CSS文件鏈接到HTML文檔中。這種方法的優勢在于可以在多個頁面間共享同一個樣式文件,有助于保持代碼的整潔和一致性。

          示例:

          <head>
          <link rel="stylesheet" type="text/css" href="mystyle.css">
          </head>
          <body>
          <h1>This is a heading</h1>
          <p>This is a paragraph.</p>
          </body>
          其中,mystyle.css的內容可能如下:
          body {background-color: powderblue;}
          h1 {color: blue;}
          p {color: red;}


          1.4 導入樣式

          使用@import語句在CSS文件中導入另一個CSS文件。盡管這種方法可以分離樣式表,但它通常不被推薦使用,因為其加載時序可能會影響頁面渲染效率。

          示例:

          @import url('https://fonts.googleapis.com/css?family=Roboto');
          body {
          font-family: 'Roboto', sans-serif;
          }


          1.5 樣式單優先級

          作用域范圍:外部樣式表>內部樣式表>行內樣式表


          優先級:

          • 行內樣式表>內部樣式表>外部樣式表
          • 相同的樣式作用在同一個標簽上:就近原則;不同的樣式作用在同一個標簽上:疊加。
          • 加載外部樣式表或者內部樣式表時候,需要注意加載順序:加載html文件是從上向下加載的,也就是后面加載的樣式會覆蓋前面的樣式。


          二、CSS常用樣式

          2.1 字體樣式

          normal - 文字正常顯示

          italic - 文本以斜體顯示

          oblique - 文本為“傾斜”(傾斜與斜體非常相似,但支持較少)

          font-weight 屬性指定字體的粗細

          示例:

          <!DOCTYPE html>
          <html>
          <head>
          <style>
          .sp1{
          color: darkorange;
          font-size: 20px;
          font-weight: bolder; /* bolder 字體是否加粗*/
          
          font-style: italic; /* italic 字體是否傾斜*/
          
          font-family: "宋體"; /* 設置字體樣式*/
          }
          
          .sp2{
          /* 簡寫 */
          /* 順序不能能變:style-weigth-size-family */
          font:italic bolder 15px 宋體 ;
          color:rgb(28, 235, 97);
          }
          </style>
          <body>
          <span>
          編程學習,從云端源想開始!
          </span><br>
          <span>
          讓知識觸手可及
          </span>
          <p>讓知識觸手可及</p>
          </body>
          </html>



          2.2 文本樣式

          color: 字體顏色

          text-align: center; - - 文本對齊方式

          text-decoration:none; - - 文本的線

          text-shadow: pink 5px 5px 2px; - - 文本的陰影 【陰影顏色-水平方向的偏移量-垂直方向的偏移量-模糊距離】

          line-height: - - 行高 (文本在標簽內所占的高度)

          width:

          height:

          border: 1px #ffffff solid; - - 盒子邊框【邊框粗細-顏色-邊框線樣式】

          示例:

          <style>
          .p{
          color: rgb(0, 255, 21); /* 字體顏色 */
          text-align: center; /* 文本對齊方式 */
          text-decoration:none; /* 文本的線 */
          text-shadow: pink 5px 5px 2px; /* 文本的陰影 【陰影顏色-水平方向的偏移量-垂直方向的偏移量-模糊距離】*/
          line-height: 400px; /* 行高 (文本在標簽內所占的高度)*/
          width: 400px;
          height: 300px;
          border: 1px rgb(76, 14, 223) solid; /* 盒子邊框【邊框粗細-顏色-邊框線樣式】 */
          }
          </style>
          </head>
          
          <body>
          <p>歡迎來到云端源想!</p>
          <a href="https://www.baidu.com"></a>
          </body>


          2.3 背景樣式

          width: 500px;

          height: 1200px;

          background-color: pink; - - 背景顏色

          background-image: url(…/img/background.jpg); - - 背景圖片

          background-repeat: no-repeat; - - 背景圖片是否平鋪

          background-position: left top; - - 指定背景圖片的位置

          background-attachment: fixed; - - 背景圖片是否隨著標簽滾動 【fixed-固定 scroll-滾動】

          示例:

          <style>
          .d{
          width: 500px;
          height: 1200px;
          background-color: pink; /* 背景顏色 */
          background-image: url(../img/background.jpg); /* 背景圖片 */
          background-repeat: no-repeat; /* 背景圖片是否平鋪 */
          background-position: left top; /* 指定背景圖片的位置 */
          background-attachment: fixed; /* 背景圖片是否隨著標簽滾動 【fixed-固定 scroll-滾動】 */
          }
          </style>
          </head>
          <body>
          <div>
          
          </div>


          2.4 列表樣式

          <!DOCTYPE html>
          <html>
          <head>
          <style>
          li{
          background-color: lemonchiffon;
          /*列表樣式:常用取值:none-無樣式 square-正方形 circle-空心圓 decimal-數字*/
          list-style-type: circle;
          /*列表樣式為自定義圖片*/
          list-style-image: url(../img/2.jpg);
          /*列表樣式的放置位置*/
          list-style-position: inside;
          /*列表樣式縮寫*/
          list-style: square url(../img/2.jpg) inside;
          /*常用的列表樣式*/
          list-style: none;
          }
          </style>
          </head>
          <body>
          <ul>
          <li>列表項1</li>
          <li>列表項2</li>
          <li>列表項3</li>
          </ul>
          </body>
          </html>


          2.5 邊框樣式

          <!DOCTYPE html>
          <html>
          <head>
          <style>
          .border{
          /*邊框寬度*/
          border-width: 2px;
          /*邊框顏色*/
          border-color: red;
          /*邊框樣式:solid 實線 dotted 點線 dashed 虛線*/
          border-style: dashed;
          /*邊框樣式縮寫:樣式 顏色 寬度*/
          border:solid green 5px;
          /*邊框可以為4個方向分別設置*/
          border-top: dashed black 4px;
          border-right: dashed #FF00FF 4px;
          border-bottom: dotted darkblue 4px;
          border-left: solid fuchsia 5px;
          /*沒有邊框*/
          border: none;
          /*常用的細邊框樣式*/
          border: solid 1px #ccc;
          }
          </style>
          </head>
          <body>
          <div class="border">這是一個帶有邊框的元素</div>
          </body>
          </html>


          2.6 盒子模型

          所有的html元素可以看做是盒子,在css中,"box model"是用來設計和布局時使用。

          CSS盒子模型本質是一個盒子,封裝周圍的html元素,它包括:邊框、邊距、填充、實際內容。

          盒子模型允許我們在其他元素和周圍元素邊框之間的空間放置元素。

          • margin:外邊距,清除邊框外區域,外邊距是透明的。
          • border:邊框,圍繞在內邊距和內容外的邊框。
          • padding:內邊距,清除內容周圍區域內邊距是透明的。
          • content:內容,顯示文字和圖像。

          想要快速入門前端開發嗎?推薦一個前端開發基礎課程,這個老師講的特別好,零基礎學習無壓力,知識點結合代碼,邊學邊練,可以免費試看試學,還有各種輔助工具和資料,非常適合新手!點這里前往學習哦!云端源想

          示例:

          <head>
          <meta charset="UTF-8">
          <title></title>
          <style>
          /* border:邊框,分4個方向,同理margin、padding也分為四個方向
          * margin:元素與元素之間對的距離
          * padding:內容與邊框之間的距離
          * 設置的時候順序:上 右 下 左
          */
          .div{
          border: solid red 10px;
          /*四個方向上的元素與元素之間的距離都是50px*/
          margin: 50px;
          /*兩個值的時候:第一個參數表示上下距離都是50px,第二個參數表示左右距離都是100px*/
          margin: 50px 100px;
          padding: 50px;
          /*
          一個元素真正的寬度=width+左右padding值+左右的border值
          一個元素的真正高度=height+上下的padding值+上下的border值
          * */
          }
          </style>
          </head>
          <body>
          <div>111111111112222222222223333333333333333</div>
          </body>

          1)盒子的寬高

          元素的實際寬度和高度:

          • 計算一個元素在實際在頁面占據的總寬度=元素寬度+左填充+右填充+左邊框+右邊框+左邊距+右邊距
          • 元素實際在頁面占據的總高度=元素高度+頂部填充+底部填充+上邊框+下邊框+上邊距+下邊距



          2)設置寬度=元素實際寬度,box-sizing屬性。

          <head>
          <meta charset="UTF-8">
          <title></title>
          <style>
          /* box-sizing:確認元素的大小
          content-box: 實際寬度=width+左右的psdding值+上下的border值
          實際高度=height+上下的padding值+上下的border值
          border-box:實際寬度=width;實際高度=height
          padding和border不會影響元素的實際寬高
          * */
          .box{
          width: 100px;
          height: 200px;
          border: 5px solid;
          padding: 5px;
          box-sizing: content-box;
          }
          </style>
          </head>
          <body>
          <div>你好中國</div>
          </body>


          CSS的世界博大精深,以上只是冰山一角,希望通過這些基礎的常用樣式可以幫助你快速進入CSS世界的大門。


          掌握CSS的引入方式和選擇器優先級是構建高效、可維護網站的關鍵。通過這些知識,你可以更好地管理和優化你的樣式代碼,創造出既美觀又專業的網頁設計。現在,準備好邁入CSS的世界,開啟你的創意之旅吧!


          我們下期再見!


          END

          文案編輯|云端學長

          文案配圖|云端學長

          內容由:云端源想分享


          主站蜘蛛池模板: 日本一区二区免费看| 一区二区中文字幕在线观看| 精品一区二区AV天堂| 无码人妻久久一区二区三区免费| 国产aⅴ精品一区二区三区久久| 色欲综合一区二区三区| 国产一区二区三区乱码| av在线亚洲欧洲日产一区二区| 国产精品无码一区二区三区毛片 | 国产一区二区中文字幕| 卡通动漫中文字幕第一区| 亚洲变态另类一区二区三区| 人妻无码一区二区三区免费| 久久精品视频一区| 精品一区二区在线观看| 国产高清不卡一区二区| 亚洲国产一区国产亚洲| 精品无码人妻一区二区三区品| 国产激情视频一区二区三区| 亚洲av无码一区二区三区不卡| 国产精品美女一区二区视频| 国产成人精品视频一区二区不卡| 国产精品区一区二区三在线播放| 亚洲AV色香蕉一区二区| 精品久久一区二区| 亚洲一区在线免费观看| 亚洲日韩AV无码一区二区三区人 | 天堂va在线高清一区| 亚洲Av无码国产一区二区 | 无码少妇一区二区| 99精品国产高清一区二区| 精品乱码一区二区三区四区| 老熟妇高潮一区二区三区| 国产一区二区三区美女| 精品一区二区三区色花堂| 无码乱人伦一区二区亚洲| 久久久精品人妻一区二区三区蜜桃| 国产精品一区二区久久精品| 无码丰满熟妇浪潮一区二区AV| 一区二区三区中文| 精品一区二区三区自拍图片区 |