The environment
- The node v12.5.0
- The system of win
- Vuecli @ vue/cli 4.5.15
- Ide WebStorm x64 2021.1
In this paper, the SPA application created by VUe-CLI is transformed into a multi-page application.
We can understand a multi-page application as an application composed of multiple single pages, and what is multiple single pages? In fact, you can think of a single page as an HTML file, and multiple single pages as multiple HTML files. A multi-page application is an application composed of multiple HTML files, as shown below:
- The article sample code repository recommends a quick look at the article – look at the sample code.
Began to transform
Change directories
- Each page of a multi-page application can have files and functions in the SRC directory of a single-page application
- in
src
Under the newpages
Folder, willPublic folder index. HTML, SRC folder app. vue, main.js
Copy it to the appropriate application folder, change the file name, and then delete it. - Create the file directory as shown in the figure below, folder name does not require but need the same entry JS, HTML file side configuration multi-page will be used.
- Take the Index folder for example
index.js
The equivalent ofmain.js
index.html
Equivalent to the public folderindex.html
index.vue
Equivalent to the SRC folderApp.vue
src
Under theThe router, store,
Whether to keep the folder depends on the specific scenario, whether the application uses one folder or needs to be separated. For example, the applicationThe router, store,
The files are so different that they need to be separated or usedThe namespaceIf they are almost the same, they can share a file (data is not shared).
Change the vue. Config. Js
- Take a look at the Vuecli documentation first
- Entry files are specified by default in single-page applications
main.js
, multi-page application entry files are includedPage1.js, page2.js, index.js
The number depends on the number of directories under the Pages folder, dynamically generating pages objects is a good choice.
Dynamically get the Pages object
- The installation
yarn add glob
Scan the folder and return the files we need
const path = require('path')
const glob = require('glob')
// Configure pages multiple pages to get HTML and JS in the current folder
function getEntry (globPath) {
const entries = {}
let basename
let tmp
let pathname
glob.sync(globPath).forEach(function (entry) {
basename = path.basename(entry, path.extname(entry))
tmp = entry.split('/').splice(-3)
pathname = basename // The correct path to output js and HTML
entries[pathname] = {
entry: 'src/' + tmp[0] + '/' + tmp[1] + '/' + tmp[1] + '.js'.template: 'src/' + tmp[0] + '/' + tmp[1] + '/' + tmp[2].title: tmp[2].filename: tmp[2].chunks: ['chunk-vendors'.'chunk-common', tmp[1]]}})return entries
}
const pages = getEntry('./src/pages/**? /*.html')
Copy the code
- The object can be obtained in the
vue.config.js
For printing
- in
vue.config.js
In themodule.exports
Object writes a multi-page configuration (that is, one more Pages configuration than a single page)
Configure dynamic import of JS CSS files
- Configure dynamic import
html-webpack-plugin
Plugin, multiple pages will exist multiple configurations only configure one will throw errors as shown below.
- Mistakes are also confusing
- You can do that
- HTML uses dynamically configured JS. The red box in the CSS diagram shows the template syntax
Complete configuration
const path = require('path')
const glob = require('glob')
// Configure pages multiple pages to get HTML and JS in the current folder
function getEntry (globPath) {
const entries = {}
let basename
let tmp
let pathname
glob.sync(globPath).forEach(function (entry) {
basename = path.basename(entry, path.extname(entry))
tmp = entry.split('/').splice(-3)
pathname = basename // The correct path to output js and HTML
entries[pathname] = {
entry: 'src/' + tmp[0] + '/' + tmp[1] + '/' + tmp[1] + '.js'.template: 'src/' + tmp[0] + '/' + tmp[1] + '/' + tmp[2].title: tmp[2].filename: tmp[2].chunks: ['chunk-vendors'.'chunk-common', tmp[1]]}})return entries
}
const pages = getEntry('./src/pages/**? /*.html')
module.exports = {
pages,
publicPath: '/'.outputDir: 'dist'.assetsDir: 'assets'.filenameHashing: true.lintOnSave: true.productionSourceMap: false.devServer: {
index: 'index.html'.// Start the serve page by default
host: '0.0.0.0'.port: 8889.https: false.hotOnly: false.proxy: null
},
chainWebpack: config= > {
Object.keys(pages).forEach(entryName= > {
// Configure dynamic import of JS and CSS
config
.plugin(`html-${entryName}`)
.tap(args= > {
args[0].cdn = []
return args
})
config.plugins.delete(`prefetch-${entryName}`)}}}Copy the code
Run-pack
Run the above configurationnpm run serve
Will run all applications
+ index access ` ` ` + page1 visit http://localhost:8889/page1/#/ http://localhost:8889/#/ ` + page2 access `http://localhost:8889/page2/#/`Copy the code
The above configuration runsRun NPM run build
It packages all the apps
- When you access an application (using the Node library HTTP-server), it will access index.html by default, so you need to specify an HTML file for all applications except index
- The index access
http://localhost:8889/#/
- Page1 access
http://localhost:8889/page1.html/#/
- Page2 access
http://localhost:8889/page2.html/#/
- The index access
- So you have to do some judgment work with pathsFor example, use character substitution
html
And other irrelevant characters.
Package a single application – take the Page1 folder as an example
- Multiple pages
pages
Multiple configurations can be used for a single applicationpages
There is only one configuration. - This requires a place for configuration, which is done using an env file.
- Root Directory Creation
.envγ.env.dev_page1γ.env.pro_page1
And write corresponding data..env
All environments are loaded to be used when all applications are packaged by default.env.dev_page1
Dev is loaded at local development time.env.pro_page1
Pro is packaged and loaded
- To change the
package.json
ηscripts
configuration
- Modify the
vue.config.js
The complete code can be found in the sample repository
To optimize the
- The above dynamic configuration of js, CSS wrote two examples, can also configure data in the.env file, specified environment load specified file
- Multiple entry JS files, introduced file configuration duplication, can extract a common JS, export a vue initialization function, store, router to do initialization.
- Other compression packaging volume is not discussed in this article (everyone must have a skill!!)
Refer to the article
+ Introduction to Vue project construction and development