Home > Web Front-end > JS Tutorial > How to develop multiple pages in vue2.0

How to develop multiple pages in vue2.0

php中世界最好的语言
Release: 2018-04-13 09:53:14
Original
1648 people have browsed it

This time I will show you how to develop multiple pages in vue2.0. What are the precautions for developing multi-pages in vue2.0. Here are practical cases, let’s take a look.

When we usually use vue to develop, we always feel that vue seems to be born specifically for single-page applications, but it is not. Because Vue relies heavily on webpack during engineering development, and webpack integrates all resources into a single page. But vue can not only make a single page, it can also make multiple pages. If you want to make multiple pages, you need to rely on it, that is, webpack needs to be reconfigured. This article will talk about the configuration of webpack in detail.

There are two ways to develop vue. One is to directly introduce the vue.js file in the script tag. If you introduce it this way, I personally feel that it will be more comfortable to make small multi-pages. Once you do a larger project, you still can't do it without it. webpack. So another method is engineering development based on webpack and vue-cli. The steps are detailed below.
Let me first state that if you use vue for engineering development, you must first have node.js, and then next npm. However, generally new versions of node will have npm, so you don’t need to do it. Instructions are entered on the command line. The first step is to generate a vue project using the command:

vue init webpack test
Copy after login

The file name declared by the blogger himself is test. After downloading, enter all the way, and then a vue project is generated. However, this vue project does not have some related dependencies. At this time, you need to enter the folder and enter the command:

npm install
Copy after login

If the network speed is not good, use cnpm install, the effect will be the same. After a few minutes, the entire dependency has been downloaded, and then enter the command:

npm run dev
Copy after login

An interface will be opened automatically. If an error is reported and the webpage cannot be opened, there is only one reason, that is, the port is occupied. At this time, you need to change the port in the /config/index.js directory.

When a vue project has completed all configurations, the next step is our focus. First, we create a few new html files. As a blogger, I created a new one.html and two.html, and their corresponding vue files. and js files, the file directory is as follows:

After that, we enter the buildwebpack.base.conf.js directory, find the entry in the module.exports domain, and configure and add multiple entries there:

entry: {
 app: './src/main.js',
 one: './src/js/one.js',
 two: './src/js/two.js'
},
Copy after login

Note that the variable name in the purple part must be chosen carefully, because it will be used later to prevent forgetting.

The next step is to modify the development environment run dev, open the buildwebpack.dev.conf.js file, and find the plugins in module.exports. The following is written as follows:

plugins: [
 new webpack.DefinePlugin({
  'process.env': config.dev.env
 }),
 // https://github.com/glenjamin/webpack-hot-middleware#installation--usage
 new webpack.HotModuleReplacementPlugin(),
 new webpack.NoEmitOnErrorsPlugin(),
 // https://github.com/ampedandwired/html-webpack-plugin
 new HtmlWebpackPlugin({
  filename: 'index.html',
  template: 'index.html',
  inject: true,
  chunks: ['app']
 }),
 new HtmlWebpackPlugin({
  filename: 'one.html',
  template: 'one.html',
  inject: true,
  chunks: ['one']
 }),
 new HtmlWebpackPlugin({
  filename: 'two.html',
  template: 'two.html',
  inject: true,
  chunks: ['two']
 }),
 new FriendlyErrorsPlugin()
]
Copy after login

The app in chunks refers to the corresponding variable name in the entry of webpack.base.conf.js. The function of chunks is that each entry will correspond to an entry every time it is compiled and run. If not written, the resources of all pages will be introduced.

Then configure the run build, which is the compilation environment. First open the configindex.js file and add this to the build:

index: path.resolve(dirname, '../dist/index.html'),
one: path.resolve(dirname, '../dist/one.html'),
two: path.resolve(dirname, '../dist/two.html'),
Copy after login

Then open the /build/webpack.prod/conf.js file, find HTMLWebpackPlugin in plugins, and add the following code:

new HtmlWebpackPlugin({
 filename: process.env.NODE_ENV === 'testing'
  ? 'index.html'
  : 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']
}),
new HtmlWebpackPlugin({
 filename: config.build.one,
 template: 'one.html',
 inject: true,
 minify: {
  removeComments: true,
  collapseWhitespace: true,
  removeAttributeQuotes: true
 },
 chunksSortMode: 'dependency',
 chunks: ['manifest', 'vendor', 'one']
}),
 new HtmlWebpackPlugin({
   filename: config.build.two,
   template: 'two.html',
   inject: true,
   minify: {
     removeComments: true,
     collapseWhitespace: true,
     removeAttributeQuotes: true
   },
   chunksSortMode: 'dependency',
   chunks: ['manifest', 'vendor', 'two']
 }),
Copy after login

The filename refers to the build in configindex.js. Each page must be configured with one chunks, otherwise the resources of all pages will be loaded.

Then the one.js file can be written like this:

import Vue from 'vue'
import one from './one.vue'
Vue.config.productionTip = false
/* eslint-disable no-new */
new Vue({
 el: '#one',
 render: h => h(one)
})
one.vue写法如下:
<template>
 <p id="one">
  {{msg}}
 </p>
</template>
<script>
export default {
 name: 'one',
 data () {
  return {
   msg: 'I am one'
  }
 }
}
</script>
Copy after login

The writing method of two is similar to it, so I won’t write it down,

Then write this in App.vue:

<template>
 <p id="app">
  <a href="one.html" rel="external nofollow" >one</a><br>
  <a href="two.html" rel="external nofollow" >two</a><br>
  {{msg}}
 </p>
</template>
Copy after login

In this way, when you open the page, clicking the one link above will jump to one.html, and clicking two will jump to two.html. This way you're done.

I believe you have mastered the method after reading the case in this article. For more exciting information, please pay attention to other related articles on the php Chinese website!

Recommended reading:

JS prompt text box email address completion

$.ajax() method how to get json from the server data

The above is the detailed content of How to develop multiple pages in vue2.0. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template