整合營銷服務(wù)商

          電腦端+手機端+微信端=數(shù)據(jù)同步管理

          免費咨詢熱線:

          用css3實現(xiàn)驚艷面試官的背景即背景動畫(高級附源碼

          用css3實現(xiàn)驚艷面試官的背景即背景動畫(高級附源碼)

          們傳統(tǒng)的前端更多的是用javascript實現(xiàn)各種復(fù)雜動畫,自從有了Css3 transition和animation以來,前端開發(fā)在動畫這一塊有了更高的自由度和格局,對動畫的開發(fā)也越來越容易。這篇文章就讓我們匯總一下使用Css3實現(xiàn)的各種特效。這篇文章參考《css揭秘》這本書,并作出了自己的總結(jié),希望能讓大家更有收獲,也強烈推薦大家看看這本書,你值得擁有。

          我們將學(xué)到

          • Css3
          • outline
          • radial-gradient
          • linear-gradient
          • box-shadow

          1.實現(xiàn)內(nèi)部虛線邊框

          知識點:outline

          核心代碼.dash-border{
           width: 200px;
           height: 100px;
           line-height: 100px;
           outline: 1px dashed #fff;
           outline-offset: -10px;
          }
          復(fù)制代碼
          

          2.邊框內(nèi)圓角的實現(xiàn)

          知識點:box-shadow

          核心代碼.radius-border{
           margin-top: 20px;
           width: 180px;
           height: 80px;
           box-shadow: 0 0 0 10px gray;
          }
          復(fù)制代碼
          

          3.實現(xiàn)條紋背景與進度條

          知識點:linear-gradient,repeating-linear-gradient

          核心代碼/* 上 */
          background: linear-gradient(to right,#fb3 50%,#58a 0);
          background-size: 40px 100%;
          box-shadow: inset 0 0 3px #555;
          /* 中 */
          background: linear-gradient(45deg,#fb3 25%,#58a 0,#58a 50%,#fb3 0,#fb3 75%,#58a 0);
          background-size: 40px 40px;
          /* 下 (可以實現(xiàn)任意角度的漸變,45°時顯示效果最好) */
          background: repeating-linear-gradient(60deg,#fb3,#fb3 15px,#58a 0,#58a 30px);
          復(fù)制代碼
          

          4.復(fù)雜的背景圖案

          知識點:linear-gradient,repeating-linear-gradient,radial-gradient

          由于第二個圖會有復(fù)雜的隨機動畫,建議大家可以親自嘗試看看效果,核心代碼

          <style>
          .bg-grid{
           margin-top: 20px;
           width: 200px;
           height: 200px;
           background-image: linear-gradient(rgba(255,255,255,1) 2px,transparent 0),
           linear-gradient(to right,rgba(255,255,255,1) 2px,transparent 0),
           linear-gradient(rgba(255,255,255,.2) 1px,transparent 0),
           linear-gradient(to right,rgba(255,255,255,.2) 1px,transparent 0);
           background-position: -50px -50px;
           background-size: 100px 100px,100px 100px, 100% 10px, 10px 100%;
          }
          .animate-grid{
           animation: move-grid 6s linear infinite;
          }
          @keyframes move-grid{
           0%{
           background-position: -50px -50px;
           }
           30%{
           background-position: -100px -100px;
           }
           60%{
           background-position: -100px -150px;
           }
           100%{
           background-position: -50px -50px;
           }
          }
          </style>
          <div class="bg-grid black-theme"></div>
          <div class="bg-grid black-theme animate-grid"></div>
          復(fù)制代碼
          

          紅綠燈以及紅路燈隨機運動動畫

          利用css3多背景和position實現(xiàn)紅綠燈和背景色塊移動核心代碼

          <style>
          .bg-dot{
           margin-top: 20px;
           width: 200px;
           height: 50px;
           background-image: radial-gradient(circle,#0cf 15px,transparent),
           radial-gradient(circle,red 15px,transparent),
           radial-gradient(circle,yellow 15px,transparent),
           radial-gradient(circle,green 15px,transparent);
           background-repeat: no-repeat;
           background-position: 0 0, 50px 0, 100px 0, 150px 0, 200px 0;
           background-size: 50px 50px;
          }
          .animate-dot{
           animation: move-dot 8s linear infinite;
          }
          .animate-dot2{
           animation: move-dot2 6s linear infinite;
          }
          @keyframes move-dot{
           0%{
           background-position: 0 0, 50px 0, 100px 0, 150px 0;
           }
           30%{
           background-position: 50px 0, 0 0, 100px 0, 150px 0;
           }
           60%{
           background-position: 50px 0, 100px 0, 0 0, 150px 0;
           }
           100%{
           background-position: 50px 0, 100px 0, 150px 0, 0 0;
           }
          }
          @keyframes move-dot2{
           0%{
           background-image: radial-gradient(circle,#0cf 15px,transparent),
           radial-gradient(circle,gray 15px,transparent),
           radial-gradient(circle,gray 15px,transparent),
           radial-gradient(circle,gray 15px,transparent);
           }
           30%{
           background-image: radial-gradient(circle,gray 15px,transparent),
           radial-gradient(circle,red 15px,transparent),
           radial-gradient(circle,gray 15px,transparent),
           radial-gradient(circle,gray 15px,transparent);
           }
           60%{
           background-image: radial-gradient(circle,gray 15px,transparent),
           radial-gradient(circle,gray 15px,transparent),
           radial-gradient(circle,yellow 15px,transparent),
           radial-gradient(circle,gray 15px,transparent);
           }
           100%{
           background-image: radial-gradient(circle,gray 15px,transparent),
           radial-gradient(circle,gray 15px,transparent),
           radial-gradient(circle,gray 15px,transparent),
           radial-gradient(circle,green 15px,transparent);
           }
          }
          </style>
          <div class="bg-dot black-theme animate-dot"></div>
          <div class="bg-dot black-theme animate-dot2"></div>
          復(fù)制代碼
          

          棋盤背景以及棋盤背景隨機動畫

          利用背景漸變實現(xiàn)棋盤圖案核心代碼

          <style>
          .bg-qi{
           margin-top: 20px;
           width: 200px;
           height: 200px;
           background-color: #eee;
           background-image: linear-gradient(45deg,rgba(0,0,0,.25) 25%,transparent 0,transparent 75%,rgba(0,0,0,.25) 0),
           linear-gradient(45deg,rgba(0,0,0,.25) 25%,transparent 0,transparent 75%,rgba(0,0,0,.25) 0);
           background-position: 0 0, 20px 20px;
           background-size: 40px 40px;
           box-shadow: 2px 2px 4px rgba(0,0,0,.4);
          }
          </style>
          <div class="bg-qi black-theme"></div>
          復(fù)制代碼
          

          偽隨機背景

          利用背景漸變,keyframe動畫,實現(xiàn)復(fù)雜的偽隨機動畫核心代碼

          <style>
          .bg-line-rand{
           margin-top: 20px;
           width: 480px;
           height: 60px;
           background-color: #eee;
           background-image: linear-gradient(90deg,#fb3 11px, transparent 0),
           linear-gradient(90deg,#ab4 23px, transparent 0),
           linear-gradient(90deg,#655 41px, transparent 0);
           background-size: 41px 100%, 61px 100%, 83px 100%;
           box-shadow: 2px 2px 4px rgba(0,0,0,.4);
          }
          .bg-dot-rand{
           margin-top: 20px;
           width: 200px;
           height: 200px;
           background-color: #eee;
           background-image: radial-gradient(circle,#fb3 5px, transparent 0),
           radial-gradient(circle,#ab4 13px, transparent 0),
           radial-gradient(circle,#655 31px, transparent 0);
           background-repeat: no-repeat;
           background-size: 101px 203px, 147px 60px, 373px 201px;
           box-shadow: 2px 2px 4px rgba(0,0,0,.4);
          }
          .animate1{
           animation: move 4s linear infinite;
          }
          .animate2{
           animation: move2 4s linear infinite;
          }
          @keyframes move{
           0%{
           background-position: 0 0, 0 0, 0 0;
           }
           50%{
           background-position: -10px 0, 20px 0, 30px 0;
           }
           100%{
           background-position: 0 0, 30px 0, 10px 0;
           }
          }
          @keyframes move2{
           0%{
           background-position: 0 0, 0 0, 0 0;
           }
           50%{
           background-position: -10px 30px, 20px 0, -40px 80px;
           }
           100%{
           background-position: 0 20px, 60px -20px, 10px 30px;
           }
          }
          </style>
          <div class="bg-line-rand black-theme"></div>
          <div class="bg-line-rand black-theme animate1"></div>
          <div class="bg-dot-rand black-theme animate2"></div>
          復(fù)制代碼
          

          5.折角效果

          知識點:linear-gradient

          核心代碼

          <style>
          .fold{
           margin-left: auto;
           margin-right: auto;
           margin-bottom: 20px;
           width: 200px;
           height: 80px;
           color: #fff;
           line-height: 80px;
           text-align: center;
           background: linear-gradient(to left bottom,transparent 50%,rgba(0,0,0,.5) 0) no-repeat 100% 0 / 2em 2em,
           linear-gradient(-135deg,transparent 1.4em,#06c 0);
          }
          .linear{
           background: linear-gradient(to left bottom,transparent 50%,rgba(0,0,0,.5)) no-repeat 100% 0 / 2em 2em,
           linear-gradient(-135deg,transparent 1.4em,#06c);
          }
          </style>
          <div class="fold">折角效果哦</div>
          <div class="fold linear">折角效果哦</div>
          復(fù)制代碼
          

          2.內(nèi)陰影圓折角效果

          核心代碼

          <style>
          .fold-1{
           margin-left: auto;
           margin-right: auto;
           margin-bottom: 20px;
           position: relative;
           width: 200px;
           height: 80px;
           border-radius: .5em;
           color: #fff;
           line-height: 80px;
           text-align: center;
           background: linear-gradient(-150deg,transparent 1.5em, #58a 0);
          }
          .fold-1::before{
           content: "";
           position: absolute;
           top: 0;
           right: 0;
           background: linear-gradient(to left bottom,transparent 50%,rgba(0,0,0,.2) 0,rgba(0,0,0,.4)) 100% 0 no-repeat;
           width: 1.73em;
           height: 3em;
           transform: translateY(-1.3em) rotate(-30deg);
           transform-origin: bottom right;
           border-bottom-left-radius: inherit;
           box-shadow: -.2em .2em .3em -.1em rgba(0,0,0,.15);
          }
          </style>
          <div class="fold-1">折角效果哦</div>
          復(fù)制代碼
          

          6.自適應(yīng)文本的條紋背景

          知識點:linear-gradient,line-height,background-origin

          核心代碼

          <style>
          .stripe-bg{
           padding: .5em;
           line-height: 1.5em;
           background: beige;
           background-size: auto 3em;
           background-origin: content-box;
           background-image: linear-gradient(rgba(0,0,0,.2) 50%, transparent 0);
          }
          .stripe-bg > p{
           margin: 0;
          }
          </style>
          <div class="stripe-bg">
           <p>hello you</p>
           <p>hello you</p>
           <p>hello you</p>
           <p>hello you</p>
           <p>hello you</p>
          </div>
          復(fù)制代碼
          

          7.自定義的下劃線實現(xiàn)

          知識點linear-gridient

          小伙伴們注意到了嗎?默認(rèn)的下劃線會將文字穿過,而上面的不會呦!

          核心代碼

          <style>
          .my-line{
           line-height: 1.4em;
           background: linear-gradient(gray,gray) no-repeat;
           background-size: 100% 1px;
           background-position: 0 1.15em;
           text-shadow: .05em 0 #fff, -.05em 0 #fff;
          }
          </style>
          <div class=""><span class="my-line">i have your big apple.you have a too? hi hi hi.</span></div>
          復(fù)制代碼
          

          最后

          筆者3天后將推出開源的CMS系統(tǒng),技術(shù)架構(gòu):

          • 后臺Node+Koa+redis+JsonSchema
          • 管理后臺界面 vue-cli3 + vue + ts + vuex + antd-vue + axios
          • 客戶端前臺 react + antd + react-hooks + axios

          平時開發(fā)中,有時候會碰到下面這種“弧形”樣式,主要分為“內(nèi)凹”和“外凸”兩種類型,如下

          該如何實現(xiàn)呢?或者想一下,有哪些 CSS 屬性和“弧形”有關(guān)?下面介紹 3 種方式,一起看看吧

          一、border-radius

          通常情況下,我們用border-radius都是這樣

          div{
            border-radius: 20px;
          }
          


          這樣表示 4 個角都是圓角,并且是標(biāo)準(zhǔn)的正圓

          其實,border-radius還支持斜杠的寫法,比如

          div{
            border-radius: 20px / 10px;
          }
          


          這表示,圓角是一個x半徑為20px,y半徑為10px的橢圓,如下

          放大來看,其實是這樣的

          進一步,我們將x半徑設(shè)置成50%,這樣就能得到一個完整的弧形了

          div{
            border-radius: 50% / 20px;
          }
          


          效果如下

          這樣就得到了“外凸”的弧形了,是不是很容易?

          至于“內(nèi)凹”弧形,單純的border-radius表示無能為力,可以看接下來的方式

          二、偽元素+border-radius

          這個其實大多數(shù)同學(xué)都能想到的方式,一個矩形和一個橢圓組合起來,不就是一個弧形卡片了嗎?原理非常簡單

          用代碼實現(xiàn)就是

          div{
            position: relative;
          }
          div::after{
            content: '';
            position: absolute;
            width: 100%;
            height: 20px;
            border-radius: 100%;
            background: inherit; /* 繼承父級背景 */
            bottom: 0;
            left: 50%;
            transform: translate(-50%,50%);
          }
          


          效果如下(虛線表示偽元素的邊緣)

          用偽元素的好處是,可以隨意控制弧度的大小位置,這個是border-radius所不能比的

          通過overflow:hidden裁剪多余部分,可以得到一個邊緣比較“鋒利”的弧形,如下所示

          另外,用偽元素還能實現(xiàn)“內(nèi)凹”的效果,不過這需要反過來思考,什么意思呢?之前是給偽元素加的背景,現(xiàn)在需要加在偽元素的外圍,這里用box-shadow實現(xiàn),原理如下

          用代碼實現(xiàn)就是

          div{
            background: none;
            overflow: hidden;
          }
          div::after{
            content: '';
            background: none;
            box-shadow: 0 0 0 9999vh #FFE8A3; /*足夠大的陰影*/
            z-index: -1;
          }
          


          效果如下(虛線表示偽元素的邊緣)

          三、徑向漸變

          提到圓弧,還可以想到徑向漸變,沒錯,這里通過徑向漸變也能輕易實現(xiàn)弧形卡片效果。

          先來看“外凸”的,其實思路和偽元素一樣,先拆分,一個橢圓和一個矩形,對應(yīng)的就是徑向漸變(radial-gradient)和線性漸變(linear-gradient),如下

          用代碼實現(xiàn)就是

          div{
            background: 
              radial-gradient(closest-side, #9747FF 100%,transparent 0) center bottom/100% 20px no-repeat,
              linear-gradient(#FFE8A3, #FFE8A3) 0 0/100% calc(100% - 10px) no-repeat;
          }
          


          效果如下(紫色部分是徑向漸變)

          再來看“內(nèi)凹”的弧形,其實也和偽元素思路類似,只不過這里需要繪制一個足夠大的漸變,從透明到純色的徑向漸變,示意如下

          調(diào)整好漸變中心點,用代碼實現(xiàn)就是

          div{
            background: radial-gradient(50% 10px at center bottom, transparent 100%,#FFE8A3 0) center bottom;
          }
          


          效果如下(全部都是徑向漸變繪制)

          當(dāng)然你也可以隨意改變徑向的弧度和大小,來實現(xiàn)各種不同的效果。

          以上所有demo都可以查看以下在線鏈接

          • CSS radius layout (codepen.io)

          四、優(yōu)缺點總結(jié)

          以上就是本文的全部內(nèi)容了,共介紹了 3 種不同的方式,下面總結(jié)一下各自優(yōu)缺點

          1. border-radius 支持斜杠語法,可以單獨控制圓弧的x、y半徑,實現(xiàn)“外凸”圓弧最簡單,缺點是圓弧不能自定義弧度,也不能實現(xiàn)“內(nèi)凹”效果
          2. 偽元素最符合常規(guī)思維,可以解決以上問題,缺點是需要占用偽元素,略微麻煩
          3. 漸變實現(xiàn)和偽元素拼接思路類似,缺點是語法復(fù)雜,需要熟練掌握漸變語法


          作者:XboxYan
          鏈接:https://juejin.cn/post/7308434314777788426

          order 盒子邊框

          復(fù)合屬性。設(shè)置對象邊框的特性。

          盒子邊框三要素:

          ① 邊框粗細(xì)

          ② 邊框樣式

          ③ 邊框顏色

          語法:border: border-width | border-style | border-color ;

          邊框四邊的粗細(xì)、樣式、顏色,以及上下左右每個位置的樣式屬性都是可以單獨調(diào)整的。

          邊框的顏色不是必要的,如果不指定顏色,默認(rèn)顏色為黑色,但必須為盒子指定寬高。


          初始 HTML

           <!DOCTYPE html>
           <html>
           <head>
               <meta charset="UTF-8">
               <meta name="viewport" content="width=device-width, initial-scale=1.0">
               <title>Document</title>
               <style>
                   div{
                       width: 500px;
                       height: 50px;
                   }
               </style>
           </head>
           <body>
               <div></div>
           </body>
           </html>




          邊框樣式

          使用 border-style 可為盒子邊框設(shè)置樣式,以下示例為實線

           /* CSS代碼 */
           div{
               width: 500px;
               height: 50px;
               border-style: solid; 
           }

          效果:


          可單獨針對某一方向設(shè)置邊框樣式

          示例 CSS 代碼

          • 上邊:border-top-style: double; (雙線)
          • 右邊:border-right-style: solid; (實線)
          • 下邊:border-bottom-style: dashed; (虛線)
          • 左邊:border-left-style: dotted; (點線)


          border-style 說明

          • 如果提供全部四個參數(shù)值,將按上、右、下、左的順序作用于四邊。
          • 如果只提供一個,將用于全部的四邊。
          • 如果提供兩個,第一個用于上、下,第二個用于左、右。
          • 如果提供三個,第一個用于上,第二個用于左、右,第三個用于下。
          • 如果border-width等于0,本屬性將失去作用。

          如果需要設(shè)置不同方向的樣式屬性,可以寫在一句 CSS 代碼里,比如說下面這段代碼,上下實線,左右虛線。

           /* CSS代碼 */
           div{
               width: 500px;
               height: 50px;
               border-style: solid dashed;
           }

          效果:


          border-style 樣式屬性值

          屬性值解釋none無輪廓。 border-color將被忽略,border-width計算值為0,除非邊框輪廓為圖像,即border-image。hidden隱藏邊框。IE7及以下尚不支持dotted點狀輪廓。IE6下顯示為dashed效果dashed虛線輪廓solid實線輪廓double雙線輪廓。兩條單線與其間隔的和等于指定的border-width值groove3D凹槽輪廓ridge3D凸槽輪廓inset3D凹邊輪廓outset3D凸邊輪廓




          邊框粗細(xì)

          使用 border-width 可為盒子邊框設(shè)置粗細(xì),以下示例邊框為 5px 粗細(xì)

           /* CSS代碼 */
           div{
               width: 500px;
               height: 50px;
               border-style: solid;
               border-width: 5px;
           }

          效果


          可單獨針對某一方向設(shè)置邊框粗細(xì)

          示例 CSS 代碼

          • 上邊:border-top-width: 10px; (雙線)
          • 右邊:border-right-width: 10px; (實線)
          • 下邊:border-bottom-width: 10px; (虛線)
          • 左邊:border-left-width: 10px; (點線)


          border-width 說明

          • 如果提供全部四個參數(shù)值,將按上、右、下、左的順序作用于四邊。
          • 如果只提供一個,將用于全部的四邊。
          • 如果提供兩個,第一個用于上、下,第二個用于左、右。
          • 如果提供三個,第一個用于上,第二個用于左、右,第三個用于下。
          • 如果border-style設(shè)置為none或hidden,border-width的使用值將為0。

          如果需要設(shè)置不同方向的邊框粗細(xì),可以寫在一句 CSS 代碼里。

          比如說下面這段代碼,上下2px,右2px,左5px。

           /* CSS代碼 */
           div{
               width: 500px;
               height: 50px;
               border-style: solid;
               border-width:2px 2px 2px 5px;
           }

          效果:




          邊框顏色

          可直接輸入

          顏色的英文名稱

          rgb值

          十六進制

          使用 border-color 可為盒子邊框設(shè)置顏色,以下示例邊框顏色為紅色。

           /* CSS代碼 */
           div{
               width: 500px;
               height: 50px;
               border-style: solid;
               border-width:2px 2px 2px 5px;
               border-color: red;
           }

          效果:


          可單獨針對某一方向設(shè)置邊框顏色

          示例 CSS 代碼

          • 上邊:border-top-color: 10px;
          • 右邊:border-right-color: 10px;
          • 下邊:border-bottom-color: 10px;
          • 左邊:border-left-color: 10px;


          border-color 說明

          • 如果提供全部四個參數(shù)值,將按上、右、下、左的順序作用于四邊。
          • 如果只提供一個,將用于全部的四邊。
          • 如果提供兩個,第一個用于上、下,第二個用于左、右。
          • 如果提供三個,第一個用于上,第二個用于左、右,第三個用于下。
          • 如果border-width等于0或border-style設(shè)置為none,本屬性將被忽略。

          上面有兩個示例講述如何設(shè)置不同方向的屬性,border-color 也是相同使用方法,此處就不做示例了。




          border 是復(fù)合屬性

          如果你需要同時設(shè)置盒子的粗細(xì)、樣式、顏色,那么你可以將他們的樣式表寫在同一行代碼里。

          例如:

           /* CSS代碼 */
           div{
               border-top: 5px solid red;
           }

          這段代碼指定了上邊框的三個屬性:粗細(xì)、樣式、顏色

          border-top 包含了:

          • border-top-width: 5px;
          • border-top-style: solid;
          • border-top-color: red;

          其他同理




          教你用 CSS 畫個三角形

          先來看一個示例

           /* CSS代碼 */
           div{
               width: 100px;
               height: 100px;
               border-top: 50px solid red;
               border-right: 50px solid blue;
               border-bottom: 50px solid green;
               border-left: 50px solid pink;
           }

          效果:

          細(xì)心的你,一定發(fā)現(xiàn)了 border 的邊框四條邊交接處是斜角。


          此刻我們把盒子的寬高設(shè)置為 0

           /* CSS代碼 */
           div{
               width: 0;
               height: 0;
               border-top: 50px solid red;
               border-right: 50px solid blue;
               border-bottom: 50px solid green;
               border-left: 50px solid pink;
           }

          效果:

          是不是完完全全像四個三角形一樣。

          我們只需要把上邊和左右兩邊的三角形隱藏起來,它不就是一個三角形了。

          為 border-color 指定 transparent 值,使盒子邊框顏色變透明

           /* CSS代碼 */
           div{
               width: 0;
               height: 0;
               border-top: 50px solid transparent;
               border-right: 50px solid transparent;
               border-bottom: 50px solid green;
               border-left: 50px solid transparent;
           }

          效果:

          把另外三條邊透明之后,就只剩一個三角形了。





          部分資料引用自:

          • http://caibaojian.com/css3/properties/border/index.htm

          主站蜘蛛池模板: 亚洲AV日韩综合一区| 国产伦精品一区二区三区视频猫咪 | 亚洲一区二区三区乱码A| 国产成人一区二区三区高清| 一本色道久久综合一区| 国产传媒一区二区三区呀| 久久婷婷色综合一区二区| 国产免费一区二区三区在线观看| 老熟妇仑乱一区二区视頻| 韩国一区二区三区| 三上悠亚精品一区二区久久| 日韩一区二区在线观看视频| 韩国精品一区二区三区无码视频 | 国产成人免费一区二区三区| 欧美日本精品一区二区三区 | 免费视频精品一区二区| 色狠狠色狠狠综合一区| 亚洲一区在线视频观看| 日本在线一区二区| 精品在线一区二区| 日韩精品无码一区二区三区不卡| 香蕉久久一区二区不卡无毒影院| 国产一区二区精品| 福利视频一区二区牛牛| 美女视频一区三区网站在线观看| 久久无码人妻精品一区二区三区| 国产精品毛片一区二区| 亚洲一区二区三区丝袜| 2021国产精品视频一区| 国产精品美女一区二区视频| 综合激情区视频一区视频二区| 日韩人妻无码一区二区三区99| 国产精品男男视频一区二区三区 | 国产美女视频一区| 久久免费视频一区| 精品无人区一区二区三区在线| 正在播放国产一区| 日韩成人无码一区二区三区| 国内精品一区二区三区东京| 亚洲国产欧美国产综合一区 | 高清一区二区三区|