vue 如何實(shí)現(xiàn)多頁面應(yīng)用

我們平時(shí)開發(fā) vue項(xiàng)目的時(shí)候,就有一種感覺就是 vue就像是專門為單頁應(yīng)用而誕生的,因?yàn)槿思业墓俜轿臋n中也說了

其實(shí)不是的,因?yàn)関ue在工程化開發(fā)的時(shí)候依賴于 webpack ,而webpack是將所有的資源整合到一塊后形成一個(gè)html文件 一堆 js文件, 如果將vue實(shí)現(xiàn)多頁面應(yīng)用,就需要對他的依賴進(jìn)行重新配置,也就是修改webpack的配置文件.
vue的開發(fā)有兩種,一種是直接的在script標(biāo)簽里引入vue.js文件即可凌那,這樣子引入的話個(gè)人感覺做小型的多頁面會(huì)比較舒坦吟逝,一旦做大型一點(diǎn)的項(xiàng)目,還是離不開webpack澎办。所以另一種方法也就是基于webpack和vue-cli的工程化開發(fā)局蚀。下面詳解步驟。

首先第一步:
進(jìn)入\build\webpack.base.conf.js目錄下琅绅,在module.exports的域里,找到entry料祠,在那里配置添加多個(gè)入口:

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

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

第二步:
對開發(fā)環(huán)境run dev里進(jìn)行修改髓绽,打開\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']
    }),
在這里插入圖片描述

這里的配置比較重要 ,如果沒寫好的 在打包的時(shí)候就會(huì)報(bào)錯(cuò)了, 在chunks那里的app指的是webpack.base.conf.js的 entry 那里與之對應(yīng)的變量名来涨。chunks的作用是每次編譯启盛、運(yùn)行時(shí)每一個(gè)入口都會(huì)對應(yīng)一個(gè)entry,如果沒寫則引入所有頁面的資源僵闯。也就是沒有改項(xiàng)目配置前形成的單頁應(yīng)用

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

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张漂,然后添加如下代碼:
其實(shí)復(fù)制粘貼改吧改吧就能用

new HtmlWebpackPlugin({
        filename: config.build.index,
        template: 'index.html',
        inject: true,
        minify: {
            removeComments: true,
            collapseWhitespace: true,
            removeAttributeQuotes: true
            
        },
        chunksSortMode: 'dependency',
        //(在這里和你上面chunks里面的名稱對應(yīng))
        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航攒,每個(gè)頁面都要配置一個(gè)chunks,不然會(huì)加載所有頁面的資源漠畜。

上面的操作完成之后進(jìn)行下面的傻瓜式操作 對咱們創(chuàng)建的文件進(jìn)行碼代碼
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 打包文件

在這里插入圖片描述

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

會(huì)報(bào)一個(gè)錯(cuò),就是找不到文件
少了一步,
在這里插入圖片描述

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

項(xiàng)目跑起來了 點(diǎn)進(jìn)去看看
在這里插入圖片描述

OK 完成!!!

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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末瘾敢,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子簇抵,更是在濱河造成了極大的恐慌,老刑警劉巖晃财,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件典蜕,死亡現(xiàn)場離奇詭異雏逾,居然都是意外死亡郑临,警方通過查閱死者的電腦和手機(jī)屑宠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進(jìn)店門典奉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人卫玖,你說我怎么就攤上這事∩驴浚” “怎么了脱茉?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長税肪。 經(jīng)常有香客問我榜田,道長,這世上最難降的妖魔是什么箭券? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任邦鲫,我火速辦了婚禮灸叼,結(jié)果婚禮上庆捺,老公的妹妹穿的比我還像新娘。我一直安慰自己捉腥,他們只是感情好你画,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布桃漾。 她就那樣靜靜地躺著拟逮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪恋追。 梳的紋絲不亂的頭發(fā)上罚屋,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天,我揣著相機(jī)與錄音撕彤,去河邊找鬼猛拴。 笑死,一個(gè)胖子當(dāng)著我的面吹牛漆弄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播廉邑,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼倒谷,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了牵祟?” 一聲冷哼從身側(cè)響起抖格,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎雹拄,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體坪哄,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年模暗,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了念祭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,094評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡顾孽,死狀恐怖比规,靈堂內(nèi)的尸體忽然破棺而出拦英,到底是詐尸還是另有隱情,我是刑警寧澤疤估,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布铃拇,位于F島的核電站,受9級特大地震影響慷荔,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜贷岸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一磷雇、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧螟蒸,春花似錦、人聲如沸七嫌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽皮假。三九已至,卻和暖如春惹资,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背猴誊。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工侮措, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人分扎。 一個(gè)月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓畏吓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親菲饼。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 第一步:安裝環(huán)境 需要安裝的有: nodejs镐确,并添加入環(huán)境變量PATH 使用nodejs安裝vue-cli 參考...
    喵吉呀呀閱讀 2,958評論 1 5
  • 前言 vue如果改成多頁辫塌,可以減少每次渲染的包大小派哲,每個(gè)頁面也可以成為一個(gè)新的單頁臼氨,可以更合理劃分業(yè)務(wù)內(nèi)容芭届。分別寫...
    xurna閱讀 2,968評論 0 0
  • 原文http://www.cnblogs.com/libin-1/p/6596810.html 版本號 vue-c...
    tengrl閱讀 3,634評論 0 0
  • 好久沒有寫日記了褂乍。。逃片。今天我專心學(xué)習(xí)webpack,跟著網(wǎng)上的文章請練完這16個(gè)webpack小例子翻譯阮一峰大神...
    還有誰叫李狗蛋閱讀 5,097評論 1 6
  • 提到運(yùn)營绝编,很多新人都會(huì)問,運(yùn)營是什么十饥?身在互聯(lián)網(wǎng)公司祖乳,最熟悉的三個(gè)部門無非就是產(chǎn)品逗堵、技術(shù)和運(yùn)營眷昆,前兩個(gè)都很好說,而...
    澤宇呀閱讀 4,594評論 5 9