vue 如何實現多頁面應用

我們平時開發(fā) vue項目的時候,就有一種感覺就是 vue就像是專門為單頁應用而誕生的,因為人家的官方文檔中也說了

其實不是的,因為vue在工程化開發(fā)的時候依賴于 webpack ,而webpack是將所有的資源整合到一塊后形成一個html文件 一堆 js文件, 如果將vue實現多頁面應用,就需要對他的依賴進行重新配置,也就是修改webpack的配置文件.
vue的開發(fā)有兩種,一種是直接的在script標簽里引入vue.js文件即可,這樣子引入的話個人感覺做小型的多頁面會比較舒坦,一旦做大型一點的項目,還是離不開webpack。所以另一種方法也就是基于webpack和vue-cli的工程化開發(fā)。下面詳解步驟。

首先第一步:
進入\build\webpack.base.conf.js目錄下,在module.exports的域里,找到entry,在那里配置添加多個入口:

// 文件路徑更具自己的實際情況進行配置,我這僅是 demo
entry: {
    app: './src/main.js',
    one: './src/js/one.js',
    two: './src/js/two.js'
  },
在這里插入圖片描述

這里的 one two 一定時要先在這里定義好的,后面是要用到的,好比 里面的app 不是隨便瞎寫的

第二步:
對開發(fā)環(huán)境run dev里進行修改,打開\build\webpack.dev.conf.js文件,在module.exports那里找到plugins,下面寫法如下:

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']
    }),
在這里插入圖片描述

這里的配置比較重要 ,如果沒寫好的 在打包的時候就會報錯了, 在chunks那里的app指的是webpack.base.conf.js的 entry 那里與之對應的變量名。chunks的作用是每次編譯、運行時每一個入口都會對應一個entry,如果沒寫則引入所有頁面的資源。也就是沒有改項目配置前形成的單頁應用

第三步:
對run build也就是編譯環(huán)境進行配置。首先打開\config\index.js文件,在build里加入這個:

index: path.resolve(__dirname, '../dist/index.html'),
one: path.resolve(__dirname, '../dist/one.html'),
two: path.resolve(__dirname, '../dist/two.html'),
在這里插入圖片描述

這里也就是打包之后dist文件夾中形成的 html

第四步:
打開/build/webpack.prod.conf.js文件,在 plugins 那里找到 HTMLWebpackPlugin,然后添加如下代碼:
其實復制粘貼改吧改吧就能用

new HtmlWebpackPlugin({
        filename: config.build.index,
        template: 'index.html',
        inject: true,
        minify: {
            removeComments: true,
            collapseWhitespace: true,
            removeAttributeQuotes: true
            
        },
        chunksSortMode: 'dependency',
        //(在這里和你上面chunks里面的名稱對應)
        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']
    }),
在這里插入圖片描述

其中filename引用的是\config\index.js里的build,每個頁面都要配置一個chunks,不然會加載所有頁面的資源。

上面的操作完成之后進行下面的傻瓜式操作 對咱們創(chuàng)建的文件進行碼代碼
one.js文件可以這樣寫:

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>
  <div id="one">
    {{msg}}
  </div>
</template>

<script>
export default {
  name: 'one',
  data () {
    return {
      msg: 'I am one'
    }
  }
}
</script>

tow 文件中的代碼一樣 我就不寫了
主要步驟我寫完了,咱們試試打包文件 輸入 npm run build 打包文件

在這里插入圖片描述

沒有問題, 跑一下項目看看 npm run dev
在這里插入圖片描述

會報一個錯,就是找不到文件
少了一步,
在這里插入圖片描述

就是一定要在index.html的同級目錄下創(chuàng)建one.html 與 two.html
在這里插入圖片描述

項目跑起來了 點進去看看
在這里插入圖片描述

OK 完成!!!

再此附上我的QQ: 2489757828 有問題的話可以共同探討
我的博客: 李大玄

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

  • 第一步:安裝環(huán)境 需要安裝的有: nodejs,并添加入環(huán)境變量PATH 使用nodejs安裝vue-cli 參考...
    喵吉呀呀閱讀 3,023評論 1 5
  • 前言 vue如果改成多頁,可以減少每次渲染的包大小,每個頁面也可以成為一個新的單頁,可以更合理劃分業(yè)務內容。分別寫...
    xurna閱讀 3,034評論 0 0
  • 原文http://www.cnblogs.com/libin-1/p/6596810.html 版本號 vue-c...
    tengrl閱讀 3,864評論 0 0
  • 好久沒有寫日記了。。。今天我專心學習webpack,跟著網上的文章請練完這16個webpack小例子翻譯阮一峰大神...
    還有誰叫李狗蛋閱讀 5,175評論 1 6
  • 提到運營,很多新人都會問,運營是什么?身在互聯網公司,最熟悉的三個部門無非就是產品、技術和運營,前兩個都很好說,而...
    澤宇呀閱讀 4,859評論 5 9

友情鏈接更多精彩內容