A plugin that bundle multiple page based-on vue-cli. Unlike
vue-cli's pages
configuration, it's handled by sharding multiple pages into different webpack configurations
Install the plugin in your project created by vue-cli, if not please refer to Not Vue-CLI created Project
vue add multiple-page
Here are 3 commands for this plugin:
init-config
: initializevue.config.js
&Views.json
two files to your projectbuild-multi
: build multiple page in parallelwatch-multi
: watch multiple page in parallel
You can use vue-cli-service [command]
in your project
The command will be generates vue.config.js
、Views.json
files if your project haven't corresponding files
The command will be build you entries where above generated configurations
, and you can specify the entry by pass --key
option, e.g:
vue-cli-service build-multi --key page,page1 # build page,page1 two entries
Views.json
:
{
"basePath": "resources/assets/js/views",
"destBasePath": "public/js/v",
"entry": {
"page": {
"srcPath": "page",
"name": "index",
"output": "page-index",
"description": "test page"
},
"page1": {
"srcPath": "page1",
"name": "index",
"output": "page1-index",
"description": "test page1"
}
}
}
The configuration file above will generates the following corresponding paths:
- entry: [
yourProject/resources/assets/js/views/page/index.js
,yourProject/resources/assets/js/views/page1/index.js
] - output: [
yourProject/public/js/v/page-index/index.js
,yourProject/public/js/v/page1-index/index.js
]
This command, like the vue-cli-service watch
command, It listens for changes to the entry file of configuration by passing the specified --key
to bundle (in watch
mode)
The plugin provides the ability to customize the configuration so that you can programmatically expose the configuration of multiple pages by creating a file called multiple-page.config.js
:
const path = require('path')
const resolve = name => path.resolve(__dirname, name)
const basePath = resolve('resources/assets/js/views')
const outputPath = resolve('public/js/v')
module.exports = {
page: {
entry: path.join(basePath, 'page/index.js'),
output: path.join(outputPath, 'page-index'),
description: 'test page',
extract: true,
chunkName: 'index'
},
page1: {
entry: path.join(basePath, 'page1/index.js'),
output: path.join(outputPath, 'page1-index'),
description: 'test page1',
chunkName: 'index'
}
}
If you have both files (Views.json
、multiple-page.config.js
) in your root directory, The multiple-page.config.js
file have a higher priority.
If your project is not created by vue-cli. please refer to the following steps. (This scenario is suitable for older, multiple-page projects that are rendered primarily by backend template engines)
step1
: Installing these dependencies in your project if you haven't installed them
yarn add @vue/cli-service vue-template-compiler --dev
yarn add vue
step2
: Add the following script commands to your package.json
file:
{
"scripts": {
"init:config": "vue-cli-service init-config",
"watch": "vue-cli-service watch-multi",
"build": "vue-cli-service build-multi"
}
}
step3
: Add this plugin to your project
vue add multiple-page
Finally Enjoy the same features as vue-cli
- [] test cases