zoukankan      html  css  js  c++  java
  • vue-cli的项目加入骨架屏

    在原生APP中我们经常可以看到,打开app时候,内容还没出来,app会被别的内容替代,这样很好的提升了用户体验。那么在webApp中,我们如何避免白屏的尴尬情况呢?可以通过 vue-skeleton-webpack-plugin这个插件来实现类似的效果。

    1.首先需要安装这个插件 npm install vue-skeleton-webpack-plugin  -S

    2.我们在src目录下创建 Skeleton.vue

    <template>
      <div class="skeleton-wrapper">
        <header class="skeleton-header"></header>
        <section class="skeleton-block">
          <img src="">
          <img src="">
        </section>
      </div>
    </template>
     
    <script>
      export default {
        name: 'skeleton'
      }
    </script>
     
    <style scoped>
      .skeleton-header {
        height: 40px;
        background: #1976d2;
        padding:0;
        margin: 0;
         100%;
      }
      .skeleton-block {
        display: flex;
        flex-direction: column;
        padding-top: 8px;
      }
     
    </style>

    3.创建入口文件:entry-skeleton.js

    import Vue from 'vue'
    import Skeleton from './Skeleton'
    export default new Vue({
      components: {
        Skeleton
      },
      template: '<Skeleton />'
    })

    4.我们在build 目录下创建 webpack.skeleton.conf.js

    'use strict';
     
    const path = require('path')
    const merge = require('webpack-merge')
    const baseWebpackConfig = require('./webpack.base.conf')
    const nodeExternals = require('webpack-node-externals')
     
    function resolve(dir) {
      return path.join(__dirname, dir)
    }
     
    module.exports = merge(baseWebpackConfig, {
      target: 'node',
      devtool: false,
      entry: {
        app: resolve('../src/entry-skeleton.js')
      },
      output: Object.assign({}, baseWebpackConfig.output, {
        libraryTarget: 'commonjs2'
      }),
      externals: nodeExternals({
        whitelist: /.css$/
      }),
      plugins: []
    })

    在后在webpack.dev.conf.js和webpack.prod.conf.js分别引入 webpack.skeleton.conf.js

     new SkeletonWebpackPlugin({
          webpackConfig: require('./webpack.skeleton.conf'),
          quiet: true
        })

    这样大功告成,我们在页面加载比较慢的时候不至于出现白屏的尴尬状况了。

  • 相关阅读:
    jQuery实现复选框全选、全不选、反选问题解析
    春节回来后至今的工作汇总
    后台管理的权限
    谨记:新增逻辑和编辑逻辑的相同和不同
    html5的本地数据库
    php做api接口的一些随笔
    js setTimeout
    在jquery选中器中使用变量
    jQuery ajax用get方法传递给api数组
    关键词处理,表格内容分类处理
  • 原文地址:https://www.cnblogs.com/linxing/p/11060267.html
Copyright © 2011-2022 走看看