Penjelasan terperinci tentang cara menggunakan CSS tulen untuk merealisasikan animasi pudar teks berbilang baris

青灯夜游
Lepaskan: 2022-10-14 19:21:34
ke hadapan
1701 orang telah melayarinya
<p>Artikel ini akan meneroka beberapa animasi teks yang menarik dalam situasi teks berbilang baris. Berbanding dengan teks satu baris, adegan teks berbilang baris adalah lebih rumit Namun, dalam perniagaan sebenar, terdapat juga banyak teks berbilang baris, tetapi pemprosesan kesannya akan lebih sukar daripada teks satu baris.

<p>Penjelasan terperinci tentang cara menggunakan CSS tulen untuk merealisasikan animasi pudar teks berbilang baris

<p>[Belajar perkongsian video: tutorial video css, bahagian hadapan web]

Baris tunggal dan Fade out daripada teks berbilang baris

<p> Mula-mula, mari kita lihat contoh di mana kita mahu melaksanakan fade out daripada satu baris teks:

<p>

<p> Menggunakan mask, anda boleh mencapai kesan ini dengan mudah, hanya:

<p>Lorem ipsum dolor sit amet consectetur.</p>
Salin selepas log masuk
p {
    mask: linear-gradient(90deg, #fff, transparent);
}
Salin selepas log masuk
<p> Tetapi bagaimana jika adegan itu menjadi berbilang baris? Kita perlu memadamkan baris terakhir teks berbilang baris dan menyesuaikannya dengan senario berbilang baris yang berbeza:

<p>

<p>Ini lebih rumit sedikit, tetapi terdapat banyak Ini boleh dicapai dengan beberapa cara.

<p>Mula-mula mari kita lihat cara menggunakan background.

Gunakan <span style="font-size: 18px;">background</span>latar belakang untuk melaksanakan

<p>display: inline akan digunakan di sini Satu helah ialah bentuk persembahan background untuk display: block elemen sebaris tidak konsisten dengan inline-block elemen peringkat blok (atau flex, grid,

). <p>

Contoh mudah:
<p>Lorem .....</p>
<a>Lorem .....</a>
Salin selepas log masuk
<p><p>Perlu diperhatikan di sini bahawa elemen ialah elemen peringkat blok<a> dan ialah elemen sebaris

. <p>

Kami menambah warna latar belakang kecerunan dari hijau ke biru secara seragam:
p, a {
  background: linear-gradient(90deg, blue, green);
}
Salin selepas log masuk
<p>

Lihat kesannya: <p>

<p>

Apa yang dilakukannya maksudnya? Perbezaannya adalah jelas. Latar belakang elemen peringkat blok ialah kecerunan secara keseluruhan, manakala setiap baris elemen sebaris mempunyai kesan yang berbeza, dan keseluruhannya disambung secara bersiri untuk membentuk keseluruhan. <p>

Berdasarkan ciri ini, kami boleh membina reka letak sedemikian:
<p><a>Mollitia nostrum placeat consequatur deserunt velit ducimus possimus commodi temporibus debitis quam</a></p>
Salin selepas log masuk
p {
    position: relative;
    width: 400px;
}

a {
    background: linear-gradient(90deg, transparent, transparent 70%, #fff);
    background-repeat: no-repeat;
    cursor: pointer;
    color: transparent;
    
    &::before {
        content: "Mollitia nostrum placeat consequatur deserunt velit ducimus possimus commodi temporibus debitis quam";
        position: absolute;
        top: 0;
        left: 0;
        color: #000;
        z-index: -1;
    }
}
Salin selepas log masuk
<p>

Penjelasan diperlukan di sini:
  • <p>backgroundSecara teratur untuk memanfaatkan Teks sebenar ciri <a> elemen sebaris sebenar, kita perlu membungkus teks sebenar dalam elemen sebaris

  • <p>opacity: 0Teks sebenar disembunyikan menggunakan <a> , teks sebenar yang dipaparkan menggunakan elemen pseudo bagi elemen -1 dan menetapkan tahapnya kepada

    , untuk membolehkan latar belakang elemen induk menutupinya
  • Dengan cara ini, kita boleh mendapatkan sesuatu seperti ini Kesan: <p><a>

Di sini, kecerunan elemen <p> adalah daripada lutsinar kepada putih, menggunakan bahagian belakang putih untuk menutup teks secara beransur-ansur.

<p>Jika saya menukar kecerunan daripada hitam kepada putih (untuk memudahkan pemahaman, hitam dan putih kecerunan mempunyai sedikit ketelusan), anda boleh memahami dengan cepat perkara yang sedang berlaku:

<p><a>

<p>Untuk kod lengkap, anda boleh klik di sini:

CodePen Demo -- Teks pudar
a {
    background: linear-gradient(90deg, rgba(0,0,0, .8), rgba(0,0,0, .9) 70%, rgba(255, 255, 255, .9));
}
Salin selepas log masuk
<p>Sudah tentu penyelesaian ini mempunyai banyak masalah, Contohnya , jika

digunakan, jika bekas induk menetapkan warna latar belakang, ia akan menjadi tidak sah dan tidak mudah untuk meletakkan baris terakhir dengan tepat. Oleh itu, cara yang lebih baik ialah menggunakan <p> untuk menyelesaikannya.

<p>Gunakan z-index: -1masktopeng

untuk melaksanakan <span style="font-size: 18px;">mask</span> Kemudian, jika anda menggunakan , masalah akan menjadi lebih mudah Kami hanya perlu melaksanakan dua kawasan dalam satu , satu untuk mengawal baris terakhir dengan tepat, dan satu untuk mengawal ketelusan bahagian yang tinggal.

<p> Tidak perlu membina HTML secara khusus: maskmaskmask

Kesannya adalah seperti berikut: <p>

<p>Lorem ipsum dolor sit amet ....</p>
Salin selepas log masuk
p {
    width: 300px;
    padding: 10px;
    line-height: 36px;
    mask: 
        linear-gradient(270deg, transparent, transparent 30%, #000),
        linear-gradient(270deg, #000, #000);
    mask-size: 100% 46px, 100% calc(100% - 46px);
    mask-position: bottom, top;
    mask-repeat: no-repeat;
}
Salin selepas log masuk
<p>核心在于整个 mask 相关的代码,正如上面而言的,mask 将整个区域分成了两块进行控制:

<p>

<p>在下部分这块,我们利用 mask 做了从右向左的渐隐效果。并且利用了 mask-position 定位,以及 calc 的计算,无论文本都多少行,都是适用的!需要说明的是,这里的 46px 的意思是单行文本的行高加上 padding-bottom 的距离。可以适配任意行数的文本:

<p>

<p>完整的代码,你可以戳这里:CodePen Demo -- Text fades away 2

添加动画效果

<p>好,看完静态的,我们再来实现一种**动态的文字渐隐消失。

<p>整体的效果是当鼠标 Hover 到文字的时候,整个文本逐行逐渐消失。像是这样:

<p>

<p>这里的核心在于,需要去适配不同的行数,不同的宽度,而且文字是一行一行的进行消失。

<p>这里核心还是会运用上内联元素 background 的特性。在 妙用 background 实现花式文字效果 这篇文章中,我们介绍了这样一种技巧。

<p>实现整段文字的渐现,从一种颜色到另外一种颜色

<div class="button">Button</div>
<p><a>Lorem ipsum dolor sit amet consectetur adipisicing elit. Mollitia nostrum placeat consequatur deserunt velit ducimus possimus commodi temporibus debitis quam, molestiae laboriosam sit repellendus sed sapiente quidem quod accusantium vero.</a></p>
Salin selepas log masuk
a {    
    background: 
        linear-gradient(90deg, #999, #999),
        linear-gradient(90deg, #fc0, #fc0);
    background-size: 100% 100%, 0 100px;
    background-repeat: no-repeat;
    background-position: 100% 100%, 0 100%;
    color: transparent;
    background-clip: text;
}
.button:hover ~ p a {
    transition: .8s all linear;
    background-size: 0 100px, 100% 100%;
}
Salin selepas log masuk
<p>这里需要解释一下,虽然设置了 color: transparent,但是文字默认还是有颜色的,默认的文字颜色,是由第一层渐变赋予的 background: linear-gradient(90deg, #999, #999), linear-gradient(90deg, #fc0, #fc0),也就是这一层:linear-gradient(90deg, #999, #999)

<p>

<p>当 hover 触发时,linear-gradient(90deg, #999, #999) 这一层渐变逐渐消失,而另外一层 linear-gradient(90deg, #fc0, #fc0)` 逐渐出现,借此实现上述效果。

<p>CodePen -- background-clip 文字渐现效果

<p>好,我们可以借鉴这个技巧,去实现文字的渐隐消失。一层为实际的文本,而另外一层是进行动画的遮罩,进行动画的这一层,本身的文字设置为 color: transparent,这样,我们就只能看到背景颜色的变化。

<p>大致的代码如下:

<p>
    <a class="word">Mollitia nostrum placeat consequatur deserunt.</a>
    <a class="pesudo">Mollitia nostrum placeat consequatur deserunt.</a>
</p>
Salin selepas log masuk
p {
    width: 500px;
}
.word {
    position: absolute;
    top: 0;
    left: 0;
    color: transparent;
    color: #000;
}
.pesudo {    
    position: relative;
    background: linear-gradient(90deg, transparent, #fff 20%, #fff);
    background-size: 0 100%;
    background-repeat: no-repeat;
    background-position: 100% 100%;
    transition: all 3s linear;
    color: transparent;
}
p:hover .pesudo,
p:active .pesudo{
    background-size: 500% 100%;
}
Salin selepas log masuk
<p>其中,.word 为实际在底部,展示的文字层,而 pesudo 为叠在上方的背景层,hover 的时候,触发上方元素的背景变化,逐渐遮挡住下方的文字,并且,能适用于不同长度的文本。

<p>

<p>当然,上述方案会有一点瑕疵,我们无法让不同长度的文本整体的动画时间一致。当文案数量相差不大时,整体可以接受,文案相差数量较大时,需要分别设定下 transition-duration 的时长。

<p>完整的 DEMO,你可以戳:CodePen -- Text fades away Animation

<p>原文地址:https://www.cnblogs.com/coco1s/p/16590809.html

<p>作者:ChokCoco

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

Atas ialah kandungan terperinci Penjelasan terperinci tentang cara menggunakan CSS tulen untuk merealisasikan animasi pudar teks berbilang baris. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
css
sumber:cnblogs.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!