vue项目添加多页面配置

公司使用vue-cli建立的vue项目在初始化时并无作多页面配置,随着需求的不断增长,发现有必要使用多页面配置。看了不少vue多页面配置的文章,基本都是在初始化时就配置了多页面。并且若是使用这些实现,须要调整当前项目的目录结构,这点也是不能接受的。
最后,参考这些文章,在不调整当前项目目录结构实现了多页面的配置的添加。这里作下记录、总结,方便之后复用。若是还能有幸帮助到有一样需求的童鞋的话,那就更好了。html

实现步骤

  1. 添加新增入口相关文件;
  2. 使用变量维护多入口;
  3. 开发环境读取多入口配置;
  4. 生产环境读取多入口配置;

新增入口相关文件

src目录下新增一个page1文件夹,新建新页面的所需的相关文件(入口文件、HTML模板文件等)。我这边直接vue-cli初始化建立相关文件复制了一份到page1文件夹下。以下:vue

├─App.vue
├─main.js
├─page1.html // 这里模板文件名称须要与文件夹名称相同,方便输出模板读取
├─router
|   └index.js
├─components
|     └HelloWorld.vue
├─assets
|   └logo.png

page1/router/index.js须要对该页面的全部路由添加同文件夹名的公共路径,用于解析:webpack

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/page1/components/HelloWorld' // 这里也须要留意
Vue.use(Router)

export default new Router({
  mode: 'history',
  base: '/',
  routes: [
    {
      path: '/page1/',
      redirect: '/page1/index'
    },
    {
      path: '/page1/index',
      name: 'HelloWorld',
      component: HelloWorld
    }
  ]
})

使用变量维护多入口

咱们在项目目录下的build/utils.js的最后exports一个指定多入口的对象。以下:nginx

// 这里,每一个属性就是一个页面配置,指定该页面的入口文件
// 若是须要添加,只需多增长一个属性
// 属性名必和html模板文件名、目录名称相同
exports.multipleEntrys = {
  page1: './src/page1/main.js'
}

之因此使用build/utils.js,是由于该文件在webpack.base.conf.jswebpack.prod.conf.jswebpack.dev.conf.js都用导入。git

开发环境读取多入口配置

首先,在build/webpack.base.conf.js中,咱们把上面定义的入口添加进entry配置:github

entry: {
    app: './src/main.js',
    ...utils.multipleEntrys  // entry添加该行
  }

而后,在build/webpack.dev.conf.js添加路径解析和多页面输出:web

// 添加解析,将historyApiFallback的属性修改以下:
    historyApiFallback: {
      rewrites: [
        // 将全部多入口遍历成路径解析项
        ...((()=>{
          let writes = []
          for(let prop in utils.multipleEntrys){
            // 使用属性名匹配为正则
            // 这就是上面“须要对该页面的全部路由添加同文件夹名的公共路径”的缘由
            let reg = new RegExp(`^/${prop}/`) 
            writes.push({
              from: reg,
              // 使用属性名读取模板文件
              // 这就是上面“模板文件名称须要与文件夹名称相同”的缘由
              to: path.posix.join(config.dev.assetsPublicPath, `${prop}.html`)
            })
          }
          return writes
        })()),
        // 匹配全部路径必定要在最后,不然该匹配以后的项,不会被执行
        { from: /.*/, to: path.posix.join(config.dev.assetsPublicPath, 'index.html') } 
      ],
    }
// 在已经的HtmlWebpackPlugin中添加chunks配置,不然默认页面会注入全部页面的js文件
...
plugins: [
    ...
    new HtmlWebpackPlugin({
      filename: 'index.html',
      template: 'index.html',
      inject: true,
      // 增长此行,
      // 'app'为默认入口名称,若是你的默认入口不是'app'
      // 则这里须要替换
      chunks: ['manifest', 'vendor', 'app']
    })
    ...
]
...
// 在`devWebpackConfig`定义以后,紧接着添加多页面输出:
for(let prop in utils.multipleEntrys){
  devWebpackConfig.plugins.push(new HtmlWebpackPlugin({
    filename: `${prop}.html`,
    // html模板路径,使用属性名做为文件夹名称
    // 这是新页面文件夹名称须要和多入口配置变量属性名相同的缘由
    template: `./src/${prop}/${prop}.html`, 
    inject: true,
    chunks: ['manifest', 'vendor', prop],
  }))
}

最后,添加多页面相互跳转连接:vue-router

<!-- src/components/HelloWorld.vue -->
...
<a href="/page1/index" >to page B</a> 
...

<!-- src/page1/components/HelloWorld.vue -->
...
<a href="/" >to page A</a> 
...
<!-- 这里因为是多个页面的跳转,因此不能再使用router-link标签,须要使用a标签 -->

到这里,开发环境的多页面配置已经完成,从新npm run dev一下,便可多页面跳转。vue-cli

生产环境读取多入口配置

首先,在webapck.prod.config.js中添加多页面输出。npm

// 在已经的HtmlWebpackPlugin中添加chunks配置,不然默认页面会注入全部页面的js文件
...
plugins: [
    ...
    new HtmlWebpackPlugin({
      ...
      chunks: ['manifest', 'vendor', 'app'] // 增长此行
      ...
    })
    ...
]
...
// build/webapck.prod.config.js的webpackConfig定义后紧接着添加
for(let prop in utils.multipleEntrys){
  webpackConfig.plugins.push(new HtmlWebpackPlugin({
    filename: `${prop}.html`,
    template: `./src/${prop}/${prop}.html`,
    inject: true,
    chunks: ['manifest', 'vendor', prop],
    minify: {
      removeComments: true,
      collapseWhitespace: true,
      removeAttributeQuotes: true
    },
    chunksSortMode: 'dependency'
  }))
}

而后,开发环境不一样路径指向不一样输出文件是由historyApiFallback来处理的,生产就须要在web服务中将不一样路径指向打包后的不一样文件。这里以nginx为例,配置以下:

server {
    listen       92 default_server;
    listen       [::]:92 default_server;
    server_name  _;
    root         D:\vue-multi-entry\dist;


   location / {
            try_files $uri $uri/ /index.html;
    }

    location /page1/ {
            try_files $uri $uri/ /page1.html;
    }
}

以上,整个多页面的配置就已经完成。这里是完整demo

关于webpack4.x版本的差别

若是你使用的是webpack4.x版本,关于webapck.prod.config.jschunks配置的顺序就是这样的:[prop, 'manifest', 'vendor']

相关文章
相关标签/搜索