手摸手带你10分钟学会骨架屏

完整示例代码在:codepen

先来写一个骨架屏基本的DOM结构:

DOCTYPE html>
<html lang="zh">
<body>
    <div class="skeleton-card">
        <div class="skeleton-header">
            <div class="skeleton skeleton-avatar">div>
            <div class="skeleton skeleton-title">div>
        div>
        <div class="skeleton skeleton-image">div>
        <div class="skeleton skeleton-text">div>
        <div class="skeleton skeleton-text">div>
        <div class="skeleton skeleton-text short">div>
    div>
body>
html>

加一些样式:

        body {
           padding: 30px;
	         background:#e2e9e6c2;
        }

        .skeleton-card {
            width: 300px;
            background-color: #ffffff;
            border-radius: 8px;
            padding: 16px;
            box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
        }

        .skeleton {
            background-color: #e2e5e7;
            border-radius: 4px;
            margin-bottom: 12px;
            position: relative;
            overflow: hidden;
        }

        .skeleton-header {
            display: flex;
            align-items: center;
            margin-bottom: 16px;
        }

        .skeleton-avatar {
            width: 40px;
            height: 40px;
            border-radius: 50%;
            margin-right: 12px;
        }

        .skeleton-title {
            flex-grow: 1;
            height: 20px;
        }

        .skeleton-text {
            height: 14px;
        }

        .skeleton-text.short {
            width: 60%;
        }

        .skeleton-image {
            width: 100%;
            height: 150px;
            margin-bottom: 16px;
        }

现的的效果如下:

Untitled.png

骨架屏一般会有一个加载的效果,可以使用线性渐变来实现,

skeleton添加伪元素:

.skeleton::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, red, transparent);
}

使用linear-gradient 实现一个从左到右的线性渐变,效果是透明-红色-透明

为了突出这个渐变,先加了一个红色,后面会换成正常的渐变颜色,效果如下:

Untitled 1.png

然后我们添加动画让这个渐变元素动起来:

 @keyframes skeleton-loading {
        0% { transform: translateX(-100%); }
        100% { transform: translateX(100%); }
    }

动画的开始帧为translateX(-100%) ,向左移动-100%,结束帧为translateX(100%),向右移动100%,效果如下:

skeleton2.gif

最后我们修改渐变颜色:

background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);

最终效果如下,这里gif的效果不是很好,推荐在codepen里面看

skeleton3.gif

阅读全文
下载说明:
1、本站所有资源均从互联网上收集整理而来,仅供学习交流之用,因此不包含技术服务请大家谅解!
2、本站不提供任何实质性的付费和支付资源,所有需要积分下载的资源均为网站运营赞助费用或者线下劳务费用!
3、本站所有资源仅用于学习及研究使用,您必须在下载后的24小时内删除所下载资源,切勿用于商业用途,否则由此引发的法律纠纷及连带责任本站和发布者概不承担!
4、本站站内提供的所有可下载资源,本站保证未做任何负面改动(不包含修复bug和完善功能等正面优化或二次开发),但本站不保证资源的准确性、安全性和完整性,用户下载后自行斟酌,我们以交流学习为目的,并不是所有的源码都100%无错或无bug!如有链接无法下载、失效或广告,请联系客服处理!
5、本站资源除标明原创外均来自网络整理,版权归原作者或本站特约原创作者所有,如侵犯到您的合法权益,请立即告知本站,本站将及时予与删除并致以最深的歉意!
6、如果您也有好的资源或教程,您可以投稿发布,成功分享后有站币奖励和额外收入!
7、如果您喜欢该资源,请支持官方正版资源,以得到更好的正版服务!
8、请您认真阅读上述内容,注册本站用户或下载本站资源即您同意上述内容!
原文链接:https://www.shuli.cc/?p=21315,转载请注明出处。
0

评论0

显示验证码
没有账号?注册  忘记密码?