mpvue骨架屏、vue骨架屏、微信小程序骨架屏、svg骨架屏【分享笔记】

mpvue小程序骨架屏

可查看这篇文章《小程序骨架屏css

clipboard.png

原生微信小程序wxml骨架屏

可参考做者腾讯的git项目:《skeletonhtml

clipboard.png

svg骨架屏(图片会变形)

vue-content-loader使用svn图片作成骨架屏,而后判断是否有数据,进行显示隐藏vue

clipboard.png

clipboard.png

![图片上传中...]node

vue骨架屏

vue-skeleton-webpack-plugin 骨架屏框架,多种样式webpack

方法一:(SPA 中单个 Skeleton)

clipboard.png

可参考这个文章《vue-cli 构建的项目如何加入骨架屏 skeletongit

方法二:(SPA 中多个 Skeleton)

这里和方法一相同的建立和build里建立流程同样。主要修改的里面的代码:github

clipboard.png

src下建立2种骨架屏展现,而后可根据不一样路由页面,进行显示其余一种,下面实现路由分配web

/build/webpack.skeleton.conf.js 修改成:vue-cli

'use strict';

const path = require('path')
const merge = require('webpack-merge')
const baseWebpackConfig = require('./webpack.base.conf')
const nodeExternals = require('webpack-node-externals')
const utils = require('./utils')
const config = require('../config')
const isProduction = process.env.NODE_ENV === 'production'
const sourceMapEnabled = isProduction
  ? config.build.productionSourceMap
  : config.dev.cssSourceMap

function resolve(dir) {
  return path.join(__dirname, dir)
}

let skeletonWebpackConfig = 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: []
})

// important: enable extract-text-webpack-plugin
skeletonWebpackConfig.module.rules[0].options.loaders = utils.cssLoaders({
  sourceMap: sourceMapEnabled,
  extract: true
}),

module.exports = skeletonWebpackConfig

/build/webpack.dev.conf.js 和 /build/webpack.prod.conf.js 修改成小程序

const SkeletonWebpackPlugin = require('vue-skeleton-webpack-plugin')




// inject skeleton content(DOM & CSS) into HTML
new SkeletonWebpackPlugin({
  webpackConfig: require('./webpack.skeleton.conf'),
  quiet: true,
  minimize: true,
  router: {
    mode: 'hash',
    routes: [
      {
        path: '/page1',
        skeletonId: 'skeleton1'
        },
        {
          path: '/',
          skeletonId: 'skeleton2'
        },
    ]
  }
}),

由上可看到,SPA 中多个骨架屏,可根据路由进行渲染不一样的骨架模块。

若是遇到v-for/wx:for,列表的,若是动态数据,我的建议是能够写个默认数据,由于骨架屏是须要数据才能有标签,再增长class的。能够判断当前的数组是否为空,再渲染默认数据,若是数组真没数据时,于把默认数据去除,显示暂无数据页面。

若是帮助到您,给个赞或收藏吧!!!!!!!!!!!!

相关文章
相关标签/搜索