淺談Vue static 靜態(tài)資源路徑 和 style問題
我就廢話不多說了,大家還是直接看代碼吧~
// Paths assetsRoot: path.resolve(__dirname, ’../dist’), // 靜態(tài)資源輸出到二級目錄下 assetsSubDirectory: ’static’, // 靜態(tài)資源cdn地址 assetsPublicPath: ’/’,
引用的時(shí)候可直接,不用返回上一級去查找,因?yàn)榫幾g輸出后的 static 下的資源 跟 html 是在同一個(gè)目錄
<img src='http://www.intensediesel.com/bcjs/static/logo.png'></a>
如果單個(gè)vue文件里的 style 沒有用到 最好刪除掉 不然 html頁面會自動生成一個(gè) 空的style
補(bǔ)充知識:webpack+vuecli打包生成資源相對引用路徑與背景圖片的正確引用
資源相對引用路徑
問題描述
一般情況下,通過webpack+vuecli默認(rèn)打包的css、js等資源,路徑都是絕對的。
但當(dāng)部署到帶有文件夾的項(xiàng)目中,這種絕對路徑就會出現(xiàn)問題,因?yàn)榘雅渲玫膕tatic文件夾當(dāng)成了根路徑,那么要解決這種問題,就得引用相對路徑。
解決辦法
打開webpack.prod.conf.js
找到output:增加 publicPath: ’./’, 即可,如圖。
那么這樣后,資源的引用路徑就正確了。
當(dāng)然在config文件夾下的index.js中修改 assetsPublicPath: ’./’同樣也可以達(dá)到資源的相對引用。
背景圖片的引用問題
上面雖然解決了資源路徑的引用問題,但是資源里面的背景圖片,不像index.html中加載資源一樣,通過./static/js/app.js引用可以正常加載,圖片資源是通過css加載的,如 background: url('../../assets/images/logo-index.png') no-repeat;被相對打包后變成了url(static/img/logo-index.2f00bf2.png) no-repeat所以我們要保留css引用圖片的正常路徑,即:
url(../../static/img/logo-index.2f00bf2.png) no-repeat
那么就需要修改build文件夾下的utils.js代碼,如圖所示:
添加如圖所示的一行代碼,這樣不論是字體還是圖片的引用問題都能解決。
以上這篇淺談Vue static 靜態(tài)資源路徑 和 style問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. sql語句 - mysql中關(guān)聯(lián)表查詢問題2. python - django models 為生成的html元素添加樣式。3. css - chrome下a標(biāo)簽嵌套img 顯示會多個(gè)小箭頭?4. javascript - iframe 為什么加載網(wǎng)頁的時(shí)候滾動條這樣顯示?5. javascript - vscode alt+shift+f 格式化js代碼,通不過eslint的代碼風(fēng)格檢查怎么辦。。。6. html - vue項(xiàng)目中用到了elementUI問題7. javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?8. javascript - 如何將一個(gè)div始終固定在某個(gè)位置;無論屏幕和分辨率怎么變化;div位置始終不變9. mysql updtae追加數(shù)據(jù)sql語句10. javascript - 有什么比較好的網(wǎng)頁版shell前端組件?
