A simple example of developing multi-page applications with vue-cli
Create project
Use vue-cli
Create a project
$ vue init webpack vue-multiple-demo
Follow the console prompts and fill in the relevant information. After creation, go to the root directory of the project and install the dependencies.
$ cd vue-multiple-demo $ npm install
Since it is developing a multi-page application, the project is not configured vue-router
.
The simplest example
The project created through vue-cli
defaults to developing a single-page application. If you want to develop multiple pages, you need to adjust the configuration of some scripts.
Entry
Create a new demo.js
in the src
directory. For convenience, directly add main.js
Copy the content in . Then, modify the entry
of build/webpack.base.conf.js
to multiple.
entry: { app: './src/main.js', demo: './src/demo.js' },
Template
Create a new demo.html
file in the project root directory, and also copy the contents of index.html
. In order to distinguish them, only edit the content of <title></title>
.
<title>demo</title>
Publishing address
Add a new record under the build
configuration of config/index.js
.
index: path.resolve(__dirname, '../dist/index.html'), demo: path.resolve(__dirname, '../dist/demo.html'),
Production environment configuration
Adjust build/webpack.prod.conf.js
in plugins
, about html
Configuration.
Modification
new HtmlWebpackPlugin({ filename: config.build.index, template: 'index.html', inject: true, minify: { removeComments: true, collapseWhitespace: true, removeAttributeQuotes: true // more options: // https://github.com/kangax/html-minifier#options-quick-reference }, // necessary to consistently work with multiple chunks via CommonsChunkPlugin chunksSortMode: 'dependency', chunks: ['manifest', 'vendor', 'app'] }),
There are two main changes here
filename
Directly write to deathTo prevent unnecessary loading of
js
, addchunks
configuration.
Newly added
new HtmlWebpackPlugin({ filename: config.build.demo, template: 'demo.html', inject: true, minify: { removeComments: true, collapseWhitespace: true, removeAttributeQuotes: true // more options: // https://github.com/kangax/html-minifier#options-quick-reference }, // necessary to consistently work with multiple chunks via CommonsChunkPlugin chunksSortMode: 'dependency', thunks: ['manifest', 'vendor', 'demo'] }),
Preview effect
The local service is not started here, so you need to modify the loading path of the static resources , that is, change build->assetsPublicPath
in config/index.js
to ./
.
assetsPublicPath: './',
Build the application
$ npm run build
Directly open the html
file in the dist
directory to preview the effect.
Summary
At this point, the simplest example of developing multiple pages is completed.
Further optimization
In actual development, the number of pages is large, so the following configurations need to be processed in batches.
File directory
The directory structure of the source code partsrc
is as follows
assets
logo.png
- ##components
- list.js
- list.html
- ##HelloWorld.vue
- index.js
- index.html
- entries
js
file used to store the page entry - templates
Templates used to store pages
html
Files Reading directory
To facilitate reading the page directory , here use
glob to extend a method. <pre class="brush:php;toolbar:false">$ npm install glob --save-dev</pre>
After installing the dependencies, add methods in
<pre class="brush:php;toolbar:false">const glob = require('glob')
// 遍历指定目录下的文件
exports.getEntries = (dirPath) => {
let filePaths = glob.sync(dirPath);
let entries = {};
filePaths.forEach(filePath => {
let filename = filePath.match(/(\w+)\.[html|js]+/)[1];
entries[filename] = filePath;
})
return entries;
}</pre>
Modify the configuration
build/webpack.base.conf. js
entry: utils.getEntries('./src/entries/*.js'),
build/webpack.base.prod.conf.js
Delete the original
HtmlWebpackPlugin related configuration, and just traverse and add related configuration before the end of the file. <pre class="brush:php;toolbar:false">const pages = utils.getEntries('./src/templates/*.html');
for(let page in pages) {
let fileConfig = {
filename: path.resolve(__dirname, '../dist/pages/' + page + '.html'),
template: pages[page],
inject: true,
minify: {
removeComments: true,
collapseWhitespace: true,
removeAttributeQuotes: true
},
chunksSortMode: 'dependency',
thunks: ['manifest', 'vendor']
};
fileConfig.thunks.push(page);
// 添加插件配置
webpackConfig.plugins.push(new HtmlWebpackPlugin(fileConfig));
}</pre>
config/index.js
Since the output address is not configured here, the previous deletion will not affect it. However, after adjusting the directory structure, the path for loading static resources in the page must also be adjusted.
assetsPublicPath: '../',
Build and preview
$ npm run build
After the construction is completed, directly use the browser to open the
html file in the dist
directory to preview the effect. Summary
Briefly summarize the following, using
vue-cli to develop several key points of multi-page applications.
- Multiple entries
- Multiple
- HtmlWebpackPlugin
- The configuration introduced in this article may not be applicable to all development scenarios. Optimizing more and further details still requires continuous practice in actual development.
Related recommendations:
vue builds multi-page application example code sharingVue-cli creates a single page to multi-page method example Codevue cli reconstruction multi-page scaffolding example sharingThe above is the detailed content of A simple example of developing multi-page applications with vue-cli. For more information, please follow other related articles on the PHP Chinese website!

Both Python and JavaScript's choices in development environments are important. 1) Python's development environment includes PyCharm, JupyterNotebook and Anaconda, which are suitable for data science and rapid prototyping. 2) The development environment of JavaScript includes Node.js, VSCode and Webpack, which are suitable for front-end and back-end development. Choosing the right tools according to project needs can improve development efficiency and project success rate.

Yes, the engine core of JavaScript is written in C. 1) The C language provides efficient performance and underlying control, which is suitable for the development of JavaScript engine. 2) Taking the V8 engine as an example, its core is written in C, combining the efficiency and object-oriented characteristics of C. 3) The working principle of the JavaScript engine includes parsing, compiling and execution, and the C language plays a key role in these processes.

JavaScript is at the heart of modern websites because it enhances the interactivity and dynamicity of web pages. 1) It allows to change content without refreshing the page, 2) manipulate web pages through DOMAPI, 3) support complex interactive effects such as animation and drag-and-drop, 4) optimize performance and best practices to improve user experience.

C and JavaScript achieve interoperability through WebAssembly. 1) C code is compiled into WebAssembly module and introduced into JavaScript environment to enhance computing power. 2) In game development, C handles physics engines and graphics rendering, and JavaScript is responsible for game logic and user interface.

JavaScript is widely used in websites, mobile applications, desktop applications and server-side programming. 1) In website development, JavaScript operates DOM together with HTML and CSS to achieve dynamic effects and supports frameworks such as jQuery and React. 2) Through ReactNative and Ionic, JavaScript is used to develop cross-platform mobile applications. 3) The Electron framework enables JavaScript to build desktop applications. 4) Node.js allows JavaScript to run on the server side and supports high concurrent requests.

Python is more suitable for data science and automation, while JavaScript is more suitable for front-end and full-stack development. 1. Python performs well in data science and machine learning, using libraries such as NumPy and Pandas for data processing and modeling. 2. Python is concise and efficient in automation and scripting. 3. JavaScript is indispensable in front-end development and is used to build dynamic web pages and single-page applications. 4. JavaScript plays a role in back-end development through Node.js and supports full-stack development.

C and C play a vital role in the JavaScript engine, mainly used to implement interpreters and JIT compilers. 1) C is used to parse JavaScript source code and generate an abstract syntax tree. 2) C is responsible for generating and executing bytecode. 3) C implements the JIT compiler, optimizes and compiles hot-spot code at runtime, and significantly improves the execution efficiency of JavaScript.

JavaScript's application in the real world includes front-end and back-end development. 1) Display front-end applications by building a TODO list application, involving DOM operations and event processing. 2) Build RESTfulAPI through Node.js and Express to demonstrate back-end applications.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

Atom editor mac version download
The most popular open source editor

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

SublimeText3 English version
Recommended: Win version, supports code prompts!

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.
