• 页面加载骨架


    应用场景:在一些追求用户体验比较极致的应用,我们需要做比较友好的页面加载效果。

    首先我们要清楚页面的结构,然后先写好一套用来加载过渡的模板(也就是我们写好的骨架),当数据加载完成把我们的要展示的页面显示给用户看。

    骨架代码:

    HTML:

     <div class="timeline-item">
       <div class="animated-background">
         <div class="background-masker header-top"></div>
         <div class="background-masker header-left"></div>
         <div class="background-masker header-right"></div>
         <div class="background-masker header-bottom"></div>
         <div class="background-masker subheader-left"></div>
         <div class="background-masker subheader-right"></div>
         <div class="background-masker subheader-bottom"></div>
       </div>
    </div>

    CSS:

    .timeline-item {
       background: #fff;
       border: 1px solid;
       border-color: #e5e6e9 #dfe0e4 #d0d1d5;
       border-radius: 3px;
       padding: 12px;
       margin: 0 auto;
       max- 472px;
       min-height: 200px;
    }
    
    @keyframes placeHolderShimmer{
        0%{
            background-position: -468px 0
        }
        100%{
            background-position: 468px 0
        }
    }
    
    .animated-background {
        animation-duration: 1s;
        animation-fill-mode: forwards;
        animation-iteration-count: infinite;
        animation-name: placeHolderShimmer;
        animation-timing-function: linear;
        background: #f6f7f8;
        background: linear-gradient(to right, #eeeeee 8%, #dddddd 18%, #eeeeee 33%);
        background-size: 800px 104px;
        height: 40px;
        position: relative;
    }
    
    .background-masker {
        background: #fff;
        position: absolute;
    }
    
    /* Every thing below this is just positioning */
    
    .background-masker.header-top,
    .background-masker.header-bottom,
    .background-masker.subheader-bottom {
        top: 0;
        left: 40px;
        right: 0;
        height: 10px;
    }
    
    .background-masker.header-left,
    .background-masker.subheader-left,
    .background-masker.header-right,
    .background-masker.subheader-right {
        top: 10px;
        left: 40px;
        height: 8px;
         10px;
    }
    
    .background-masker.header-bottom {
        top: 18px;
        height: 6px;
    }
    
    .background-masker.subheader-left,
    .background-masker.subheader-right {
        top: 24px;
        height: 6px;
    }
    
    .background-masker.header-right,
    .background-masker.subheader-right {
         auto;
        left: 300px;
        right: 0;
    }
    
    .background-masker.subheader-right {
        left: 230px;
    }
    
    .background-masker.subheader-bottom {
        top: 30px;
        height: 10px;
    }
    
    .background-masker.content-top,
    .background-masker.content-second-line,
    .background-masker.content-third-line,
    .background-masker.content-second-end,
    .background-masker.content-third-end,
    .background-masker.content-first-end {
        top: 40px;
        left: 0;
        right: 0;
        height: 6px;
    }
    
    .background-masker.content-top {
        height:20px;
    }
    
    .background-masker.content-first-end,
    .background-masker.content-second-end,
    .background-masker.content-third-end{
         auto;
        left: 380px;
        right: 0;
        top: 60px;
        height: 8px;
    }
    
    .background-masker.content-second-line  {
        top: 68px;
    }
    
    .background-masker.content-second-end {
        left: 420px;
        top: 74px;
    }
    
    .background-masker.content-third-line {
        top: 82px;
    }
    
    .background-masker.content-third-end {
        left: 300px;
        top: 88px;
    }

    当页面正在加载的时候,我们显示这个骨架模板,然后当我们的请求完成后,把这个骨架模板替换成我们要显示的数据模板,这样就可以了。

    这是其中一种方式,当然也有其他的方式,大家可以根据这个思路自己拓展开。

  • 相关阅读:
    人生几宝
    sleep() 和 wait() 有什么区别?
    abstract class和interface有什么区别?
    谈谈final, finally, finalize的区别
    字符串转码【String.getBytes()和new String()】
    Redis中文API地址
    java之ibatis数据缓存
    ibatis的缓存机制
    mysql|表row_format的静态与动态,Compact
    Tesseract ocr 3.02学习记录一
  • 原文地址:https://www.cnblogs.com/cczlovexw/p/9618155.html
Copyright © 2020-2023  润新知