Author: Little potato Biubiubiu
Blog Park: www.cnblogs.com/HouJiao/
The Denver nuggets: juejin. Cn/user / 243617…
Wechat official account: Tudou Mother’s Broken thoughts (scan code attention, suck cats together, listen to stories together, learn front-end technology together)
The content of the author’s articles are from their own practice, if you feel helpful to you, you can like ❤️ to give an encouragement or leave valuable comments
preface
The term “skeleton screen” has been used a lot lately, but it’s a term I’ve rarely heard of before. It’s just that when browsing websites at ordinary times, you often see some placeholder graphics displayed on a page before you get real data.
In fact, this is the skeleton screen described above, that is, the general structure of the page is shown to the user before the page data is loaded, and the content of the page is displayed in detail after the data is obtained. Compared with traditional loading, the skeleton screen improves user experience to a large extent.
Therefore, this article is a preliminary study and practice of skeleton screen. The content itself is very simple, but there are still some details that need to be paid attention to, otherwise normal results cannot appear in practice.
page-skeleton-webpack-plugin
Page-skeleton-webpack-plugin is a webpack plugin developed by ele. me team, which can generate different skeleton screen pages according to different pages.
Then try the Page-skeleton-webpack-plugin in your project.
Project introduction
This project is a project generated by vuE-CLI2, the content of the components in the project is also very simple, you can poke here to get the project code.
Page – the skeleton – webpack – the plugin installation
NPM install –save-dev page-webpack-plugin is also very simple to install, simply run NPM install –save-dev page-webpack-plugin.
Note that the documentation clearly states that the htmL-webpack-plugin should also be installed. This project already has the htML-webpack-plugin installed. If the html-webpack-plugin is not installed in your project, you can install it by NPM install –save-dev html-webpack-plugin.
Then you need to get started.
Webpack configuration
The first is the code that requires us to generate skeleton screens in the development environment.
So the first step is to configure the SkeletonPlugin in your development environment.
Location: / / code/skeleton - screen - demo/build/webpack dev. Conf. Js
// Step 1: Introduce the skeleton panel module
const { SkeletonPlugin } = require('page-skeleton-webpack-plugin')
// omit code...
plugins: [
// Omit configuration code for other plug-ins...
// Step 2: Configure in the plug-in
new SkeletonPlugin({
pathname: path.resolve(__dirname, '.. /shell'), // the path to store shell file
staticDir: path.resolve(__dirname, '.. /dist'), // the same as the `output.path`
routes: ['/'].// Which routes you want to generate skeleton screen})]Copy the code
The three required configuration items of SkeletonPlugin are PathName, staticDir, and routes. These three items are useful for the following purposes:
Configuration items | The data type | role |
---|---|---|
pathname | String | Development environment click save button generated skeleton screen code save path |
staticDir | String | Static resource file generated when packaging skeleton screen (official documentation guide to andwebpack Package output directory consistent) |
routes | Array | Need to generate skeleton screen routing (and projectThe routing configuration thepath Consistent) |
Run the project
After the WebPack configuration in the development environment is complete, run the project using NPM Run dev. Unfortunately, there was an error 😤 😤 😤.
/skeleton-screen-demo/node_modules/page-skeleton-webpack-plugin/ SRC /util/index.js It was found that the file does introduce a module called webpack-log, so the solution is to install webpack-log: NPM install webpack-log –save-dev
Re-run the project after successful installation.
You can find that the project name has been started successfully and the page can be accessed normally.
The page-skeleton-webpack-plugin configuration is successful if the following information is printed on the console.
Generate skeleton screen file
Start by typing toggleBar on the console, and then hit Enter.
You can see that a bar appears at the top of the page. Click on this bar to start generating a preview of the skeleton screen.
The generation process takes more than ten seconds
You can see the preview of the skeleton screen of our page; In the third column of the preview page, you can also make changes to the generated code.
Next, click the button in the upper right corner of the Skeleton screen preview page to save the skeleton screen code in the directory configured in webPack.
After clicking the save button, you can see that the corresponding skeleton screen code file has been generated locally.
Skeleton panel configuration in the production environment
The above series of actions are all practiced in a development environment to generate skeleton screen code. Now you need to put the skeleton screen into production.
Webpack configuration
First, we need to write the skeleton screen configuration in production.
Location: / / code/skeleton - screen - demo/build/webpack pro. Conf. Js
// Step 1: Introduce the skeleton panel module
const { SkeletonPlugin } = require('page-skeleton-webpack-plugin')
// omit code...
plugins: [
// Omit configuration code for other plug-ins...
// Step 2: Configure in the plug-in
new SkeletonPlugin({
pathname: path.resolve(__dirname, '.. /shell'), // the path to store shell file
staticDir: path.resolve(__dirname, '.. /dist'), // the same as the `output.path`
routes: ['/'].// Which routes you want to generate skeleton screen})]Copy the code
This configuration is the same as the previous configuration in webpack.dev.conf.js. You can write it directly to webpack.base.conf.js to avoid having to write the configuration twice.
Template File Configuration
Add a comment
.
<! DOCTYPEhtml>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="Width = device - width, initial - scale = 1.0">
<title>Preliminary study on skeleton screen</title>
</head>
<body>
<div id="app">
<! -- shell -->
</div>
<! -- built files will be auto injected -->
</body>
</html>
Copy the code
👉👉👉 Pay attention to 👉👉👉
The html-webpack-plugin for Webpack has a configuration for compressing and removing comments, which is set to true by default when a project is built, to remove comments from a template. But on the skeleton screen, this
comments are mandatory. Therefore, we need to change the configuration item for compressing and removing comments to false, i.e. keep comments, otherwise the skeleton screen will not take effect after the later project is packaged and deployed.
new HtmlWebpackPlugin({ minify: { removeComments: false // Change the configuration item of the compressed remove comment to false }, Copy the code
Packaged build project
The project is then packaged and compiled.
Deploy the project to view the results
The final step is to deploy the project, and this time I used nginx deployment project. Once the project is successfully deployed, we can open the browser and see what the skeleton screen looks like.
The component content itself is very simple and takes a short time to load. Therefore, you need to set NetWork -> Disable cache in the browser debugging tool. Also set the loading speed to 3G(or customize the loading speed). So you can see the skeleton screen very clearly.
Multi-page skeleton screen generation
The multi-page skeleton screen is also very easy to generate. Besides creating new components and configuring the routing, the SkeletonPlugin needs to be configured.
new SkeletonPlugin({
pathname: path.resolve(__dirname, '.. /shell'), // the path to store shell file
staticDir: path.resolve(__dirname, '.. /dist'), // the same as the `output.path`
routes: ['/'.'/test'].// Which routes you want to generate skeleton screen
})
Copy the code
Add new routes to skeletonplugin. routes, and then you can switch the new routes to the skeleton preview screen to generate a new skeleton preview screen.
After the generation, click the save button to save the skeleton screen code.
After saving, a new skeleton screen code is generated locally.
After the package deployment can be.
Pay attention to the notice
In particular, the Page-skeleton-webpack-plugin has a Routes button in the Skeleton screen preview interface for switching Routes to generate different pages of the skeleton screen preview.
It can be seen that the route displayed after clicking the switch button does not have the # symbol, and we configured the route in the default hash mode, so the complete URL of accessing the two components in the browser is:
http://localhost:8080/#/
http://localhost:8080/#/test
Copy the code
After adding the test route, when I switched to the /test route in the preview interface, the preview interface still generated the skeleton page of/route.
This problem can be traced back to the implementation of the Page-skeleton-webpack-plugin. When we switch the route in the preview page, the page-skeleton-webpack-plugin will fetch the content of the corresponding component according to the route we select. The skeleton screen page is then generated from the contents of the component.
Because the Page-skeleton-webpack-plugin routes in history mode without the # symbol, and the actual project routes in hash mode, the SkeletonPlugin won’t match the actual components and won’t properly generate the skeleton screen.
The solution to this problem is very simple, isto set the project route to history mode.
// SRC /router/index.js
import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import Test from '@/components/Test'
Vue.use(Router)
export default new Router({
mode: 'history'.routes: [{path: '/'.name: 'HelloWorld'.component: HelloWorld
},
{
path: '/test'.name: 'Test'.component: Test
}
]
})
Copy the code
This problem bothered me in practice for a long time, the new pages didn’t work properly, and there was no mention of it in the documentation. Then I compared a sale example given by the government.
Finally, let’s take a look at the multi-page skeleton screen.
The last
Here, this skeleton screen preliminary study is completed, the content is very simple, but there are also one or two small pits need to avoid to perfect the skeleton screen effect.
about
The author
Small potatoes biubiubiu
For a hard-working front-end novice, knowledge is limitless. Believe that you can always get where you want as long as you don’t stop learning
At the same time, I am also a person who likes small cats. There is a beautiful short female cat named Potato at home
Blog garden
www.cnblogs.com/HouJiao/
The Denver nuggets
Juejin. Cn/user / 243617…
Wechat official account
Potato mama’s mumbo jumbo
The original purpose of the wechat official account is to record some stories about myself and people around me, while updating some technical articles from time to time
Welcome to scan code attention, suction cat, listen to stories, learn front-end technology together
The author remarks
Small summary, welcome everyone guidance ~