スネークボーダーアニメーションボタンhtml + css

効果:

ここに画像の説明を挿入

生産工程:

1.ラベルを定義します。ラベルはボタンであり、4つのスパンはボタンの周りの4つのアクションの青いエッジです。

<a href="https://blog.csdn.net/luo1831251387?spm=1000.2115.3001.5343" class="night" target="blank">
        <span></span>
        <span></span>
        <span></span>
        <span></span>
          night
    </a>

2. button.nightの基本的なスタイルを定義します。

.night{
    
    
            position: relative;
            width: 300px;
            height: 100px;
            color: rgb(18, 190, 243);
            letter-spacing: 12px;
            font-size: 50px;
            line-height: 100px;
            text-align: center;
            /* background-color: rgb(31, 49, 133); */
            background-image: linear-gradient(90deg, rgb(40, 62, 161) 50%,rgb(31, 49, 133) 50% );
            text-transform: uppercase;
            user-select: none;
            text-decoration: none;
            overflow: hidden;
            box-shadow: inset 0 0 10px rgb(14, 20, 105),
            0 0 5px rgb(9, 208, 235);
            transition: all 0.5s;
            
        }

位置:相対位置。
文字間隔:単語間隔。
線形グラデーション:グラデーションカラー。
text-transform:すべての文字は大文字です。
user-select:テキストは選択できません。
text-decoration:デフォルトの下線を削除します。
オーバーフロー:オーバーフローが非表示になります。
ボックスシャドウ:シャドウ。
遷移:遷移効果。

3.マウスオーバーボタンのスタイルの変更:

 .night:hover{
    
    
            text-shadow: 0 0 5px rgb(18, 190, 243),
            0 0 8px rgb(18, 190, 243),
            0 0 10px rgb(18, 190, 243); 
            background-image: linear-gradient(90deg, rgb(25, 38, 99) 50%,rgb(13, 22, 58) 50% );
            box-shadow: inset 0 0 10px rgb(14, 20, 105),
            0 0 5px rgb(9, 208, 235),
            0 0 10px rgb(9, 208, 235);
        }

text-shadow:テキストシャドウ。
lineear-gradient:グラデーションの色の変化。
box-shadow:ボックスの影が変わります。

4. 4スパンの基本スタイル:

  .night span{
    
    
            position: absolute;   
        }

絶対絶対ポジショニング

5.ボタンの上にある青い移動線のスタイルを設定します。

 .night span:nth-child(1){
    
    
            top: 0;
            left: 0;
            width: 100%;
            height: 2px;
            background-image: linear-gradient(to right, transparent , rgb(0, 153, 255) );
            animation: move1 2s linear infinite;
        }
        @keyframes move1 {
    
    
            0%{
    
    
                transform: translateX(-100%);
            }
            100%{
    
    
                transform: translateX(100%);
            }
        }

線形グラデーション:グラデーションカラー。透明は透明色です。
アニメーション:青い線を動かすアニメーションを設定します。
transform:translateX(-100%); X軸のオフセットは-100%です。
変換:translateX(100%); 100%にシフトさせます。

6.類推により、他の3つもアニメーションを設定し、次に左右のもののアニメーション遅延を設定します。

.night span:nth-child(2){
    
    
            top: 0;
            right: 0;
            width: 2px;
            height: 100%;
            transform: translateY(-100%);
            background-image: linear-gradient(to bottom,  transparent ,  rgb(0, 153, 255)  );            
            animation: move2 2s linear infinite;
            animation-delay: 1s;
        }
        @keyframes move2 {
    
    
           
            100%{
    
    
                transform: translateY(100%);
            }
        }
        .night span:nth-child(3){
    
    
            left: 0;
            bottom: 0;
            width: 100%;
            height: 2px;
            background-image: linear-gradient(to left, transparent , rgb(0, 153, 255) );
            animation: move3 2s linear infinite;
        }
        @keyframes move3 {
    
    
            0%{
    
    
                transform: translateX(100%);
            }
            100%{
    
    
                transform: translateX(-100%);
            }
        }
        .night span:nth-child(4){
    
    
            top: 0;
            left: 0;
            width: 2px;
            height: 100%;
            transform: translateY(100%);
            background-image: linear-gradient(to top, transparent , rgb(0, 153, 255) );
            animation: move4 2s linear infinite;
            animation-delay: 1s;
        }
        @keyframes move4 {
    
    
            100%{
    
    
                transform: translateY(-100%);
            }
        }

Animation-delay:1s;アニメーションの遅延を1秒間再生するように設定します。

完全なコード:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    
    <style>
        *{
     
     
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
        body{
     
     
            height: 100vh;
            display: flex;
            justify-content: center;
            align-items: center;
            background-color: rgb(4, 4, 19);
        }
        .night{
     
     
            position: relative;
            width: 300px;
            height: 100px;
            color: rgb(18, 190, 243);
            letter-spacing: 12px;
            font-size: 50px;
            line-height: 100px;
            text-align: center;
            /* background-color: rgb(31, 49, 133); */
            background-image: linear-gradient(90deg, rgb(40, 62, 161) 50%,rgb(31, 49, 133) 50% );
            text-transform: uppercase;
            user-select: none;
            text-decoration: none;
            overflow: hidden;
            box-shadow: inset 0 0 10px rgb(14, 20, 105),
            0 0 5px rgb(9, 208, 235);
            transition: all 0.5s;
            
        }
        .night:hover{
     
     
            text-shadow: 0 0 5px rgb(18, 190, 243),
            0 0 8px rgb(18, 190, 243),
            0 0 10px rgb(18, 190, 243); 
            background-image: linear-gradient(90deg, rgb(25, 38, 99) 50%,rgb(13, 22, 58) 50% );
            box-shadow: inset 0 0 10px rgb(14, 20, 105),
            0 0 5px rgb(9, 208, 235),
            0 0 10px rgb(9, 208, 235);
        }
            
        .night span{
     
     
            position: absolute;   
        }
        .night span:nth-child(1){
     
     
            top: 0;
            left: 0;
            width: 100%;
            height: 2px;
            background-image: linear-gradient(to right, transparent , rgb(0, 153, 255) );
            animation: move1 2s linear infinite;
        }
        @keyframes move1 {
     
     
            0%{
     
     
                transform: translateX(-100%);
            }
            100%{
     
     
                transform: translateX(100%);
            }
        }
        .night span:nth-child(2){
     
     
            top: 0;
            right: 0;
            width: 2px;
            height: 100%;
            transform: translateY(-100%);
            background-image: linear-gradient(to bottom,  transparent ,  rgb(0, 153, 255)  );            
            animation: move2 2s linear infinite;
            animation-delay: 1s;
        }
        @keyframes move2 {
     
     
           
            100%{
     
     
                transform: translateY(100%);
            }
        }
        .night span:nth-child(3){
     
     
            left: 0;
            bottom: 0;
            width: 100%;
            height: 2px;
            background-image: linear-gradient(to left, transparent , rgb(0, 153, 255) );
            animation: move3 2s linear infinite;
        }
        @keyframes move3 {
     
     
            0%{
     
     
                transform: translateX(100%);
            }
            100%{
     
     
                transform: translateX(-100%);
            }
        }
        .night span:nth-child(4){
     
     
            top: 0;
            left: 0;
            width: 2px;
            height: 100%;
            transform: translateY(100%);
            background-image: linear-gradient(to top, transparent , rgb(0, 153, 255) );
            animation: move4 2s linear infinite;
            animation-delay: 1s;
        }
        @keyframes move4 {
     
     
            100%{
     
     
                transform: translateY(-100%);
            }
        }
    </style>
</head>
<body>
    <a href="https://blog.csdn.net/luo1831251387?spm=1000.2115.3001.5343" class="night" target="blank">
        <span></span>
        <span></span>
        <span></span>
        <span></span>
          night
    </a>
</body>
</html>

総括する:

いいと思うなら、それと同じように〜
言うの忘れてしまいました。
食事の、ようやく3等に合格しました〜

その他の記事:
カラフルなストリーマーテキストhtml + css
バブルフローティング背景特殊効果html + css
シンプルクロック特殊効果html + css + js
サイバーパンクスタイルボタンhtml +
cssNetEaseクラウド公式ウェブサイトカルーセル画像を模倣html + css + js
水波ローディングアニメーションhtml + css
ナビゲーションバースクロールグラデーション効果html + css + js
ブックページめくりhtml + css3D
ステレオアルバムhtml + css
ネオン描画ボード効果html + css + js
いくつかのCSS属性の要約を覚えておいてください(1)
Sass要約メモ
...など。

おすすめ

転載: blog.csdn.net/luo1831251387/article/details/115058088
おすすめ