vue.js項目打包上線全流程
vue.js項目打包上線
最近一直堅持每個月寫一個小的vue.js 開發(fā)的項目,最后開發(fā)完成后想到很久之前給別人回答的一個問題:vue的項目如何上線,當(dāng)時有千奇百怪的回答,我在想,這些人都是腫了么,vue的官方都說了,這個框架只是做了view這一層,所以并不是把這些開發(fā)完的東西直接拷貝到服務(wù)器上,而且需要打包為靜態(tài)文件上傳服務(wù)器的。
這里我簡單的列出這個過程
首先需要修改一下配置文件再打包,很多人都是遇到過打包后運(yùn)行一片空白等等問題,這些問題主要就是路徑的問題,所以需要修改config下面的index.js這個配置文件里選項:
上圖中第一個要修改的就是靜態(tài)文件的路徑,打包后靜態(tài)文件就在當(dāng)前目錄下,所以修改為./
第二個是環(huán)境設(shè)置為生產(chǎn)環(huán)境
修改好后打開cmd運(yùn)行下面的命令打包即可:
注意下面的tip,告訴你這個打包后的文件需要放到服務(wù)器才能打開,不能直接使用瀏覽器打開,打包后的文件結(jié)構(gòu)如下:
這時我們需要使用服務(wù)器的方式來訪問index.html就可以了。這里可能很多人也會遇到一些問題,比如大家可能在開發(fā)的時候使用的proxytable來解決跨域的問題,這里就會沒有數(shù)據(jù)了,這個需要自己通過服務(wù)器在解決一下才可以的,proxytable在這里只是為了方便大家開發(fā)的跨域解決方案。
vue.js打包之后遇到的坑
最近在用webpack+vue寫項目,經(jīng)過幾天的熬夜加班改BUG,終于把基本的框架給寫完了,后面只要加一些小功能就可以了,太好吧!先來npm run build 打包出來看看吧!
打包中...,我們用本地服務(wù)器打開看一下。
額,不看不知道,一看嚇一跳,坑咋這么多呢!但是作為一名積極向上的IT從業(yè)者,填坑吧。
打包之后沒有被渲染出來
怎么回事,剛打開就告訴我啥也沒有,這是要搞事情的前奏??!,我們看一下錯誤信息,告訴我路徑有問題,默默的看一下自己的地址欄和自己的文件所在目錄,原來是我的打包文件沒有放到根目錄下,這個時候我們可以把我們的兩個文件放到根目錄下,但是作為一名有個性的IT人士,當(dāng)然要看有沒有其他方法。從上面的路徑中隱隱約約有點(diǎn)預(yù)感,static是直接相對于根目錄,說明這有可能打包的時候,有可能設(shè)置了絕對路徑,如果我改成相對路徑,那不就可以了嗎。
我們?nèi)タ匆幌马椖课募碌腸onfig>index.js找到里面的build下的assetsPublicPath:'/',把它改成assetsPublicPath:'./',加個小點(diǎn)表示相對路徑,不加表示絕對路徑。npm run build運(yùn)行。成功。
路由(router)mode:'history',導(dǎo)致頁面不能渲染
地址欄的那個#怎么那么讓我不舒服呢!對于有輕度強(qiáng)迫癥的我來說,這是不能忍不了的。
我們在項目打包前,開發(fā)項目時(npm start),在vueRouter里設(shè)置mode:"history".可以去掉#號。
這里強(qiáng)行解釋一番:
路由(router)默認(rèn) hash 模式,使用 URL 的 hash 來模擬一個完整的 URL,于是當(dāng) URL 改變時,頁面不會重新加載,因為對于正常的頁面來說,更換URl一定是會導(dǎo)致頁面的更換的, 而只有更換URL中的查詢字符串和hash值的時候才不會重新加載頁面。
路由(router)的history模式,這種模式充分利用了history.pushState API來完成URL的跳轉(zhuǎn)而不需要重新加載頁面。沒有#號。
npm run build打包中....
什么鬼,為什么我的路由(router)部分沒有被渲染出來,這就是history的坑了,解決方法一,會到以前的hash模式;解決方法二,設(shè)置routes里的路由name。
這是因為路由(router)無法找到路徑中的組件,所以也就無法渲染了。只需要修改 src > router > index.js,在每個path后加上組件名稱就行了,這樣就可以了。
這里有個小問題:
為了我們的時間考慮,還是放到根目錄吧!
首頁沒有問題了,逐個鏈接測試一下。
這是什么鬼,路徑和其他圖片路徑一樣,圖片也存在啊,為啥你就是這么傲嬌,就是報錯。來看一下控制臺。
結(jié)合之前的./原來是相對路徑問題,是我的開發(fā)文件assets下多個圖片文件夾。
這個時候為了開發(fā)項目的可讀性和維護(hù)性。只能默默的把前面改的相對路徑'./'改回絕對路徑'/'了。這就尷尬了,額額額,大家就當(dāng)沒看到哈!
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于Element-UI Table 表格指定列添加點(diǎn)擊事件
這篇文章主要介紹了關(guān)于Element-UI Table 表格指定列添加點(diǎn)擊事件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09如何配置vue.config.js 處理static文件夾下的靜態(tài)文件
這篇文章主要介紹了如何配置vue.config.js 處理static文件夾下的靜態(tài)文件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06vue實現(xiàn)播放后端flask發(fā)送的mp3文件
這篇文章主要為大家詳細(xì)介紹了vue如何實現(xiàn)播放后端flask發(fā)送的mp3文件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01vue-cli實現(xiàn)異步請求返回mock模擬數(shù)據(jù)
網(wǎng)上有不少使用mockjs模擬數(shù)據(jù)的文章,但基本都是本地攔截請求返回數(shù)據(jù),本文主要介紹了vue-cli實現(xiàn)異步請求返回mock模擬數(shù)據(jù),文中根據(jù)實例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03