溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

vue.js項(xiàng)目怎么打包上線

發(fā)布時(shí)間:2022-04-13 13:49:14 來源:億速云 閱讀:148 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“vue.js項(xiàng)目怎么打包上線”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡單快捷,實(shí)用性強(qiáng),希望這篇“vue.js項(xiàng)目怎么打包上線”文章能幫助大家解決問題。

vue.js項(xiàng)目打包上線

最近一直堅(jiān)持每個(gè)月寫一個(gè)小的vue.js 開發(fā)的項(xiàng)目,最后開發(fā)完成后想到很久之前給別人回答的一個(gè)問題:vue的項(xiàng)目如何上線,當(dāng)時(shí)有千奇百怪的回答,我在想,這些人都是腫了么,vue的官方都說了,這個(gè)框架只是做了view這一層,所以并不是把這些開發(fā)完的東西直接拷貝到服務(wù)器上,而且需要打包為靜態(tài)文件上傳服務(wù)器的。

這里我簡單的列出這個(gè)過程

首先需要修改一下配置文件再打包,很多人都是遇到過打包后運(yùn)行一片空白等等問題,這些問題主要就是路徑的問題,所以需要修改config下面的index.js這個(gè)配置文件里選項(xiàng):

vue.js項(xiàng)目怎么打包上線

上圖中第一個(gè)要修改的就是靜態(tài)文件的路徑,打包后靜態(tài)文件就在當(dāng)前目錄下,所以修改為./

第二個(gè)是環(huán)境設(shè)置為生產(chǎn)環(huán)境

修改好后打開cmd運(yùn)行下面的命令打包即可:

vue.js項(xiàng)目怎么打包上線

注意下面的tip,告訴你這個(gè)打包后的文件需要放到服務(wù)器才能打開,不能直接使用瀏覽器打開,打包后的文件結(jié)構(gòu)如下:

vue.js項(xiàng)目怎么打包上線

這時(shí)我們需要使用服務(wù)器的方式來訪問index.html就可以了。這里可能很多人也會(huì)遇到一些問題,比如大家可能在開發(fā)的時(shí)候使用的proxytable來解決跨域的問題,這里就會(huì)沒有數(shù)據(jù)了,這個(gè)需要自己通過服務(wù)器在解決一下才可以的,proxytable在這里只是為了方便大家開發(fā)的跨域解決方案。

vue.js打包之后遇到的坑

最近在用webpack+vue寫項(xiàng)目,經(jīng)過幾天的熬夜加班改BUG,終于把基本的框架給寫完了,后面只要加一些小功能就可以了,太好吧!先來npm run build 打包出來看看吧!

vue.js項(xiàng)目怎么打包上線

打包中...,我們用本地服務(wù)器打開看一下。

額,不看不知道,一看嚇一跳,坑咋這么多呢!但是作為一名積極向上的IT從業(yè)者,填坑吧。

打包之后沒有被渲染出來

vue.js項(xiàng)目怎么打包上線

怎么回事,剛打開就告訴我啥也沒有,這是要搞事情的前奏??!,我們看一下錯(cuò)誤信息,告訴我路徑有問題,默默的看一下自己的地址欄和自己的文件所在目錄,原來是我的打包文件沒有放到根目錄下,這個(gè)時(shí)候我們可以把我們的兩個(gè)文件放到根目錄下,但是作為一名有個(gè)性的IT人士,當(dāng)然要看有沒有其他方法。從上面的路徑中隱隱約約有點(diǎn)預(yù)感,static是直接相對(duì)于根目錄,說明這有可能打包的時(shí)候,有可能設(shè)置了絕對(duì)路徑,如果我改成相對(duì)路徑,那不就可以了嗎。

vue.js項(xiàng)目怎么打包上線

我們?nèi)タ匆幌马?xiàng)目文件下的config>index.js找到里面的build下的assetsPublicPath:'/',把它改成assetsPublicPath:'./',加個(gè)小點(diǎn)表示相對(duì)路徑,不加表示絕對(duì)路徑。npm run build運(yùn)行。成功。

路由(router)mode:'history',導(dǎo)致頁面不能渲染問題

vue.js項(xiàng)目怎么打包上線

地址欄的那個(gè)#怎么那么讓我不舒服呢!對(duì)于有輕度強(qiáng)迫癥的我來說,這是不能忍不了的。

我們?cè)陧?xiàng)目打包前,開發(fā)項(xiàng)目時(shí)(npm start),在vueRouter里設(shè)置mode:"history".可以去掉#號(hào)。

這里強(qiáng)行解釋一番:

路由(router)默認(rèn) hash 模式,使用 URL 的 hash 來模擬一個(gè)完整的 URL,于是當(dāng) URL 改變時(shí),頁面不會(huì)重新加載,因?yàn)閷?duì)于正常的頁面來說,更換URl一定是會(huì)導(dǎo)致頁面的更換的, 而只有更換URL中的查詢字符串和hash值的時(shí)候才不會(huì)重新加載頁面。

路由(router)的history模式,這種模式充分利用了history.pushState API來完成URL的跳轉(zhuǎn)而不需要重新加載頁面。沒有#號(hào)。

npm run build打包中....

什么鬼,為什么我的路由(router)部分沒有被渲染出來,這就是history的坑了,解決方法一,會(huì)到以前的hash模式;解決方法二,設(shè)置routes里的路由name。

vue.js項(xiàng)目怎么打包上線

這是因?yàn)槁酚桑╮outer)無法找到路徑中的組件,所以也就無法渲染了。只需要修改 src > router > index.js,在每個(gè)path后加上組件名稱就行了,這樣就可以了。

這里有個(gè)小問題:

vue.js項(xiàng)目怎么打包上線

vue.js項(xiàng)目怎么打包上線

為了我們的時(shí)間考慮,還是放到根目錄吧!

首頁沒有問題了,逐個(gè)鏈接測(cè)試一下。

vue.js項(xiàng)目怎么打包上線

vue.js項(xiàng)目怎么打包上線

這是什么鬼,路徑和其他圖片路徑一樣,圖片也存在啊,為啥你就是這么傲嬌,就是報(bào)錯(cuò)。來看一下控制臺(tái)。

vue.js項(xiàng)目怎么打包上線

結(jié)合之前的./原來是相對(duì)路徑問題,是我的開發(fā)文件assets下多個(gè)圖片文件夾。

vue.js項(xiàng)目怎么打包上線

關(guān)于“vue.js項(xiàng)目怎么打包上線”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI