只要css就能實現的骨架屏方案

線上體驗地址https://jsfiddle.net/z13wtr0q/ css

先說優缺點,畢竟骨架屏實現的方案有不少種html

優勢

  • 簡單,不須要工程,不用puppeteer生成骨架dom,也不須要二次開發維護
  • 定製程度高,想怎麼搞就怎麼搞
  • 不臃腫,只給你想要的

缺點

  • 自動化程度低,須要在骨架dom上手動添加類
  • 協同要求高,不像工程化能經過工程去約束

思路

經過僞元素實現骨架樣式,經過操做樣式實現骨架和頁面的動態切換vue

實現

css部分(scss寫法)

經過after僞元素生成骨架樣式,並經過absolute覆蓋到實際元素上react

.skt-loading {
    pointer-events: none; /* 加載中阻止事件 */
    .skeleton {
      position: relative;
      overflow: hidden;
      border: none !important;
      border-radius: 5px;
      background-color: transparent !important;
      background-image: none !important;
      &::after {
        content: '';
        position: absolute;
        left: 0;
        top: 0;
        z-index: 9;
        width: 100%;
        height: 100%;
        background-color: #EBF1F8;
        display: block;
      }
      
      /* 下面這部分都是自定義的,看需求修改 */
      &:not(.not-round)::after {
        border-radius: 4px;
      }
      &:not(.not-before)::before {
        position: absolute;
        top: 0;
        width: 30%;
        height: 100%;
        content: "";
        background: linear-gradient(to right,rgba(255,255,255,0) 0,
            rgba(255,255,255,.3) 50%,rgba(255,255,255,0) 100%);
        transform: skewX(-45deg);
        z-index: 99;
        animation: skeleton-ani 1s ease infinite;
        display: block;
      }
      &.badge {
        &::after {
          background-color: #F8FAFC;
        }
      }
    }
  }

  @keyframes skeleton-ani { /* 骨架屏動畫 */
    from {
      left: -100%;
    }
    to {
      left: 150%;
    }
  }

html部分

只須要在你認爲合理的骨架粒度元素上添加skeleton類便可dom

js部分

控制好skt-loading類的切換動畫

使用注意

  • after僞元素沒法插入到inputimg等非容器元素中,因此若是須要添加skleton,則須要再加一層元素將其包裹
  • 對於像vuereact數據驅動頁面須要先有mock數據以生成dom

歡迎各位拋磚spa

相關文章
相關標籤/搜索