• Stars
    star
    886
  • Rank 51,520 (Top 2 %)
  • Language
    JavaScript
  • Created over 7 years ago
  • Updated almost 6 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Lavas webpack plugin: skeleton solution for PWA webshell

vue-skeleton-webpack-plugin

npm version Build Status

NPM

这是一个基于 Vue 的 webpack 插件,为单页/多页应用生成骨架屏 skeleton,减少白屏时间,在页面完全渲染之前提升用户感知体验。

支持 webpack@3 和 webpack@4,支持 Hot reload。

基本实现

参考了饿了么的 PWA 升级实践一文, 使用服务端渲染在构建时渲染 skeleton 组件,将 DOM 和样式内联到最终输出的 html 中。

另外,为了开发时调试方便,会将对应路由写入router.js中,可通过/skeleton路由访问。

插件具体实现可参考我的这篇文章

使用方法

安装:

npm install vue-skeleton-webpack-plugin

运行测试用例:

npm run test

在 webpack 中引入插件:

// webpack.conf.js
import SkeletonWebpackPlugin from 'vue-skeleton-webpack-plugin';

plugins: [
    new SkeletonWebpackPlugin({
        webpackConfig: {
            entry: {
                app: resolve('./src/entry-skeleton.js')
            }
        }
    })
]

参数说明

SkeletonWebpackPlugin

  • webpackConfig 必填,渲染 skeleton 的 webpack 配置对象
  • insertAfter 选填,渲染 DOM 结果插入位置,默认值为字符串 '<div id="app">'
    • 也可以传入 Function,方法签名为 insertAfter(entryKey: string): string,返回值为挂载点字符串
  • quiet 选填,在服务端渲染时是否需要输出信息到控制台
  • router 选填 SPA 下配置各个路由路径对应的 Skeleton
    • mode 选填 路由模式,两个有效值 history|hash
    • routes 选填 路由数组,其中每个路由对象包含两个属性:
      • path 路由路径 string|RegExp
      • skeletonId Skeleton DOM 的 id string
  • minimize 选填 SPA 下是否需要压缩注入 HTML 的 JS 代码

[DEPRECATED] SkeletonWebpackPlugin.loader

开发模式已经支持 hot reload,该参数不再需要。

示例

Lavas 创建的项目

如果你的项目是使用 Lavas 创建的,可参考Lavas Appshell模版Lavas MPA模版 中的应用。

vue-cli 创建的项目

如果你的项目是使用 vue-cli 创建的,可以参考基于 Vue Webpack 模板应用这个插件的例子: SPA 中单个 Skeleton:

SPA 中多个 Skeleton:

简单的 Vue + Webpack 应用

或者你可以参考examples下的测试用例,其中也包含了单页和多页情况,具体如下:

  • /examples/simple 最简单的 SPA,使用一个 Skeleton
  • /examples/multi-skeleton SPA,根据路由使用多个 Skeleton
  • /examples/multipage MPA,每个页面使用各自的 Skeleton,使用 multipage-webpack-plugin
  • /examples/multipage2 MPA,每个页面使用各自的 Skeleton,使用多个 html-webpack-plugin
  • /examples/multipage3 MPA,page1 使用 Skeleton,page2 不使用
  • /examples/webpack4 SPA,使用 webpack@4
  • /examples/vue-cli3 SPA,使用 vue-cli@3 创建的项目

常见问题

Webpack4

插件需要使用与 Webpack 版本配套的插件进行样式分离。

  • Webpack 4 中使用 mini-css-extract-plugin 而非 extract-text-webpack-plugin,因此需要安装。
  • 安装 vue-loader@^15.0.0 并正确配置,可以参考 vue-loader 文档

未开启样式分离

运行出现如下错误:

node_modules\memory-fs\lib\MemoryFileSystem.js:114 throw new MemoryFileSystemError(errors.code.ENOENT, _path);

由于插件使用了 Vue 服务端渲染在构建时渲染 skeleton 组件,将 DOM 和样式内联到最终输出的 html 中。 因此在给 skeleton 使用的 Webpack 配置对象中需要开启样式分离,将 skeleton 使用的样式从 JS 中分离出来。

在 Webpack 中样式分离是通过 extract-text-webpack-plugin 插件实现的。因此在 webpack.skeleton.config 中必须正确配置该插件。

以使用 vue-cli 创建的项目为例,如果你的 webpack.skeleton.conf 继承自 webpack.base.conf,在开发模式下是默认关闭样式分离的,因此需要修改,可参考修改方案

压缩注入的 HTML 和 CSS

使用 html-webpack-pluginminify 选项,可以参考 #36

使用多个 Skeleton 时无法匹配当前路由路径?

用于匹配每个 Skeletonpath 选项可以填写字符串或者正则。 如果想匹配 /page1?key=value 这样的路由路径,可以直接写正则 path: /^\/page1/。可以参考 [#45]

More Repositories

1

lavas

基于 Vue 的 PWA 解决方案,帮助开发者快速搭建 PWA 应用,解决接入 PWA 的各种问题
JavaScript
1,964
star
2

pwa-book

这是一本 PWA 相关的书籍
JavaScript
164
star
3

hexo-pwa

Hexo PWA plugin
JavaScript
131
star
4

jekyll-pwa

Jekyll plugin for PWA
Ruby
101
star
5

pwa-doc

Lavas PWA documents
93
star
6

lavas-tutorial

Lavas 指导教程文档
67
star
7

pwa-book-demo

JavaScript
48
star
8

lavas-template-vue-appshell

Lavas Template with App Shell
JavaScript
45
star
9

sw-register-webpack-plugin

Lavas webpack plugin: service worker register for sw.js file no-cache solution
JavaScript
37
star
10

lavas-template-vue-mpa

Lavas Template with Multiple Page App
JavaScript
36
star
11

lavas-project.github.io

Lavas website
JavaScript
26
star
12

lavas-template-vue

Lavas Vue 模板,包括 Basic 和 AppShell
JavaScript
22
star
13

lavas-demo-blog

(Deprecated) Lavas pwa blog demo
JavaScript
19
star
14

lavas-template-vue-ssr

Lavas Template with Server Side Rendering
JavaScript
18
star
15

lavas-demo-news

Lavas webapp demo for news
JavaScript
18
star
16

pwa-lesson-demo

Demos for PWA lessons
JavaScript
18
star
17

vue-style-variables-loader

Webpack loader for loading global variable.less/styl/sass files in every vue component
JavaScript
15
star
18

lavas-template-vue-basic

Lavas Basic Template
JavaScript
9
star
19

pwa-expo

PWA 相关特性支持度说明,关注国内主流浏览器。 Updating...
9
star
20

crater

为大型WEB站点自动生成service worker,支持下属模块互不影响地缓存静态资源
JavaScript
8
star
21

kram

基于 marked、highlight.js 的文档编译系统
JavaScript
6
star
22

lavas-scaffold

Lavas 创建 PWA 工程脚手架模块
JavaScript
5
star
23

codelab

Codelabs of Lavas
4
star
24

pwa-features-autotest

Support PWA features automated testing on multi-browsers
JavaScript
2
star
25

lavas-core

JavaScript
1
star