ホームページ >ウェブフロントエンド >htmlチュートリアル >学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト

学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト

青灯夜游
青灯夜游転載
2021-04-26 11:08:152688ブラウズ

この記事では、学ぶ価値のある 6 つのフロントエンド HTML CSS 特殊効果を紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。

学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト

前書き: 学習は単に収集するだけでは終わりません。自分で学習し、自分の考えを加えなければなりません。

1. ゆっくりと絵が近づいてきます

絵を見ると、少し小さいと感じるかもしれませんが、ユーザーがマウスを移動すると、画像がゆっくり大きくなるという体験をユーザーに提供します。

レンダリング:

学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト

学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト

## 知識ポイント:

    #CSS3 "トランジション":transition()----画像の拡大方法と拡大処理の時間を定義します
  • CSS3 "2D 変換" :transform:scale()----画像を拡大します
  • ##CSS3 "overflow":overflow:hidden----画像を拡大すると、オーバーフローが非表示になります
  • コード:

<div class="imgDiv">
    <img  src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1589451318456&di=6aa6f77e865a4b51ab43b265753ab260&imgtype=0&src=http%3A%2F%2Fb-ssl.duitang.com%2Fuploads%2Fitem%2F201506%2F27%2F20150627225153_AwJYF.thumb.700_0.jpeg" alt="学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト" >
</div>

.imgDiv{
    width:300px;
    overflow: hidden;
    box-shadow: 0 1px 4px rgba(0,0,0,0.6);
    border:5px solid rgba(0,0,0,0.6);
    box-sizing: border-box;
}
.imgDiv img{
    width:300px;
}
.imgDiv img:hover{
    transform:scale(1.1) ;
    transition: 0.5s linear;
}
2. 拡大画像に特殊効果を追加する

知識ポイント:

1. CSS の「フィルター」。 2. CSS グレー フィルター: greyscale()

3. CSS セピア フィルター: sepia()



コード:

.imgDiv{
    width:300px;
    overflow: hidden;
    border:5px solid rgba(0,0,0,0.6);
    box-sizing: border-box;
    display: flex;
    flex:auto;
    margin-top:100px;
    margin-left:100px;
}
.imgDiv img{
    width:300px;
    filter:grayscale(100%);<-新增->
}
.imgDiv img:hover{
    transform:scale(1.1) ;
    transition: 0.5s linear;
    filter:grayscale(0);<-新增->
}
レンダリング:


学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト3. ソフトウェアの昼夜モード

知識ポイント:

1. CSS フィルター: invert() - 画像の色を反転します。画像の色が白の場合、invert(0) は白、invert(1) は黒、その逆も同様です。

<div>
    <div><h1>白天模式</h1></div>
<div>
    <img  alt="学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト" >
</div>
<div>
    <button>切换</button>
</div>
</div>


isChange:boolean=true;
  translate(){
    var body=document.getElementById("body");
    var text=document.getElementById("text");
    var container=document.getElementById("container");
    if(this.isChange){
      body.setAttribute("style","filter:invert(100%)");
      text.innerHTML="白天模式";
      this.isChange=false;
    }else{
      body.setAttribute("style","filter:invert(0%)");
      text.innerHTML="黑夜模式";
      this.isChange=true;
    }
  }

レンダリング:

学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト注:


これは「深刻な」昼夜モードではありません。親要素が反転フィルターを設定した後、その子要素の色も反転されるからです。これにより、写真などの子要素が元の外観を失います。
  • 反転フィルターを使用する場合は、最初に要素の背景色を設定する必要があります。そうしないと機能しません。
  • 反転フィルターは白黒を反転するだけでなく、各色に対応する反転も行います。
  • 4. デイ/ダーク モードを実現するための CSS 移行

知識ポイント:

1 . CSS トランジション:transition 2. 上記の invert() は、フォントの色を変更するためにここのサブ要素でも使用されています. js を直接使用してフォントの色属性を変換することもできますが、フィルターは効率が高くなります


コード:

<div id="body">
    <div id="translate"></div>
    <div class="text"><h1 id="text">白天模式</h1></div>
<div class="imgDiv">
    <img  src="http://img5.imgtn.bdimg.com/it/u=2473598420,2292311239&fm=26&gp=0.jpg" alt="学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト" >
</div>
<div class="container" id="container">
    <button (click)="translate()">切换</button>
</div>
</div>

<-只展示id=translate的css->
#translate{
    position: absolute;
    width:0px;
    height:0px;
    transition:width 2s,height 2s;
    background-color:black;
}

export class HoverToLargeImageComponent implements OnInit {
  isChange:boolean=true;
  translate(){
    var text=document.getElementById("text");
    var translate=document.getElementById("translate");
    if(this.isChange){
      translate.setAttribute("style","width:990px;height:690px;");
      text.innerHTML="黑夜模式";
      text.setAttribute("style","filter:invert(100%)")
      this.isChange=false;
    }else{
      translate.setAttribute("style","width:0px;height:0px");
      text.innerHTML="白天模式";
      text.setAttribute("style","filter:invert(0)")
      this.isChange=true;
    }
  }
}
#レンダリング:

注:学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト

この昼夜モードは他の要素の背景色に影響を与えないため、フォントの色が白または黒の場合は、次のコマンドでフォントの色を変更する必要があります。切り替えモードではない場合、フォントは表示されません。

  • 興味があれば、

  • 小さなコンテナを大きなコンテナの任意の部分 (たとえば中央など) に移動し、効果が現れるように設定できます。両側に広がったり、円状に現れたりします。
  • 5. ミキシング モード

知識ポイント:

CSS ミキシング モード: mix-blend -modeこの属性には 16 の値があります:

normal Normal

  • multiply multiply

  • 画面フィルターの色

  • オーバーレイ オーバーレイ

  • 暗くする 暗くする

  • 明るくする 明るくする

  • カラー回避カラー回避

    #​​
  • カラー焼き込みカラー深め

  • ハードライト強いライト

  • #ソフトライトソフトライト
  • ##差分差
  • 除外除外
  • 色相
  • #彩度 彩度

  • #色 color

  • 明度明るさ

  • コード:

  • <div class="container">
        <h1>混合模式学习</h1>
    </div>
    <div class="first background"><div class="middle"></div></div>
    <div class="second background"><div class="middle"></div></div>
    <div class="third background"><div class="middle"></div></div>
    <div class="fourth background"><div class="middle"></div></div>
    
    .first{
        background-image: url(https://source.unsplash.com/1920x1080?city);
    }
    .second{
        background-image: url(https://source.unsplash.com/1920x1080?landscape);
    }
    .third{
        background-image: url(https://source.unsplash.com/1920x1080?portrait);
    }
    .fourth{
        background-image: url(https://source.unsplash.com/1920x1080?stars);
    }
    .container,.middle:before{
        height: 200px;
        width:300px;
        position: fixed;
        box-sizing: content-box;
        top:50%;
        left:50%;
        transform: translate(-50%,-50%);
        text-align: center;
        line-height: 200px;
        mix-blend-mode: lighten;
    }
    .container{
        background-color:cornsilk;
        z-index: 10;
    }
    .background{
        height:750px;
        width:1500px;
        position: relative;
        margin:0px auto;
        background-size: cover;
        background-repeat: no-repeat;
        
    }
    .middle:before{
        content:"  ";
        padding:50px;
    }
    
    
    .middle{
        position: absolute;
        width:500px;
        height:100%;
        margin-left: 500px;
        clip:rect(auto,auto,auto,auto);
    }
    .first .middle:before{
        background-color: red;
        mix-blend-mode: lighten;
    }
    .second .middle:before{
        background-color:gold;
        mix-blend-mode: difference;
    }
    .third .middle:before{
        background-color: aqua;
        mix-blend-mode: color-dodge;
    }
    .fourth .middle:before{
        background-color: brown;
        mix-blend-mode: soft-light;
    }
  • 効果:

注:

学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクトz-index 属性: z-index 属性は、要素の積み重ね順序を設定します。積み重ね順序が高い要素は常に、積み重ね順序が低い要素よりも前にあります。 HTML 位置

は後続の要素によってカバーされる必要があるため表示できませんが、z-index を使用すると要素カバレッジの問題を解決できます。

  • isolation属性:隔离,主要与mix-blend-mode属性一起使用,将混合模式只应用于某一个元素或某一组元素。可取值:auto|isolate(创建新的堆叠上下文)。使用了isolate之后,该元素就不会再与父元素混合,而是与它的子元素混合。

  • 这里用了四张图片,四种不同的混合属性值和背景色,感受混合模式的炫。

  • 6. 视觉效果差,超炫酷

    知识点:

    CSS之背景固定:background-attachment

    上代码:

    <div>
        <div>
            <div>
                <h1>因为爱,所以爱</h1>
            </div>
        </div>
       <div>
           <div><img  alt="学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト" ></div>
           <div>
               <article>与你一见如故,是我今生最美丽的相遇。
            与你一诺相许,是我素色年华里最永恒的风景。
            一直想说,无论走到哪里,最想去的是你的身边。
            愿我们彼此相爱,一直到时间的尽头。
            我相信我们可以一起,等青丝变白发。
            你在,我在,就是海枯石烂。
            没有过多的华丽,只有一句我喜欢你,却能让彼此牵挂于心。
            亲爱的,你知道吗,哪怕遍体鳞伤,我仍有爱你的余力。
            有的人你只看了一眼,却影响其一生。
            生活就像是包饺子,不管你是什么馅,我都会紧紧的把你包在我心里,任生活的沸水怎样煮,都磨不掉		      我对你的爱!
            好久没有见你了,心中十分挂念,可是又不敢去看你,因为害怕打扰你,你会不开心,所以我尽力的控制自己思念的心。
     
    不知道这些日子,你是不是跟我一样,牵挂你,想念你;我是真的特别想你,想看看你的笑,想看看你纯真的脸;想着你,我就特别来劲,晚上都无法睡好!
                </article>
            </div>
       </div>
       <div>
           <div>
               <h1>我爱你,无畏人海的拥挤</h1>
           </div>
       </div>
       <div>
        <div>
            <h1>你小心一吻便颠倒众生  一吻便救一个人</h1>
        </div>
       </div>
     </div>
     
     
    .container {
        height: 100vh;
    }
    .parallax-img {
        background-attachment: fixed;
        background-position: center;
        background-repeat: no-repeat;
        background-size: cover;
        height: 100%;
        background-image: url("http://ppe.oss-cn-shenzhen.aliyuncs.com/collections/182/7/thumb.jpg");
    }
    .title{
        position: relative;
        width:300px;
        height: 150px;
        left: 50%;
        top:50%;
        transform: translate(-50%,-50%);
        background-color: gray;
        line-height: 150px;
        text-align: center;
        color:tan;
    } 
    .myLove{
        display: flex;
        height:400px;
        width:100%;
        background-color: gray;
    }
    .myLove div{
        width:30%;
        height: 80%;
        margin-left: 100px;
        margin-top:50px;
    }
    .myLove div img{
        width:100%;
        height:100%;
    }
    .myLove .article{
        margin-left: 250px;
    }
    .parallax-img1 {
        background-attachment: fixed;
        background-position: center;
        background-repeat: no-repeat;
        background-size: cover;
        height: 100%;
        background-image: url("http://ppe.oss-cn-shenzhen.aliyuncs.com/collections/182/5/thumb.jpg");
    }
    
    .parallax-img2{
        background-attachment: fixed;
        background-position: center;
        background-repeat: no-repeat;
        background-size: cover;
        height: 100%;
        background-image: url("http://ppe.oss-cn-shenzhen.aliyuncs.com/collections/181/10/thumb.jpg");
    }
    .parallax-img1 div,.parallax-img2 div {
        position: relative;
        left: 50%;
        top:50%;
        transform: translate(-50%,-50%);
        background-color: gray;
        width:40%;
        height:50px;
        text-align: center;
        color: tan;
    }

    效果图:

    学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクト

    注意:

    • 如果能录全屏则效果更佳,但由于图片上传大小限制,只能录制中间部分和快速拉过。如果喜欢,可以自己试试,代码已全部粘贴出来。

    • 其实就是一个CSS属性的知识,就看你如何配置图片、色效使效果更炫酷。

    • 图片能决定视图效果,因此,上面三张图片来源于原博客。

    更多编程相关知识,请访问:编程视频!!

    以上が学ぶ価値のある 6 つのフロントエンド HTML+CSS エフェクトの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    声明:
    この記事はcsdn.netで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。