您的位置:首頁技術文章
文章詳情頁

淺談Vue static 靜態資源路徑 和 style問題

瀏覽:185日期:2023-10-14 08:39:12

我就廢話不多說了,大家還是直接看代碼吧~

// Paths assetsRoot: path.resolve(__dirname, ’../dist’), // 靜態資源輸出到二級目錄下 assetsSubDirectory: ’static’, // 靜態資源cdn地址 assetsPublicPath: ’/’,

引用的時候可直接,不用返回上一級去查找,因為編譯輸出后的 static 下的資源 跟 html 是在同一個目錄

<img src='http://www.wxshucaidpc.com/bcjs/static/logo.png'></a>

如果單個vue文件里的 style 沒有用到 最好刪除掉 不然 html頁面會自動生成一個 空的style

補充知識:webpack+vuecli打包生成資源相對引用路徑與背景圖片的正確引用

資源相對引用路徑

問題描述

一般情況下,通過webpack+vuecli默認打包的css、js等資源,路徑都是絕對的。

淺談Vue static 靜態資源路徑 和 style問題

但當部署到帶有文件夾的項目中,這種絕對路徑就會出現問題,因為把配置的static文件夾當成了根路徑,那么要解決這種問題,就得引用相對路徑。

解決辦法

打開webpack.prod.conf.js

找到output:增加 publicPath: ’./’, 即可,如圖。

淺談Vue static 靜態資源路徑 和 style問題

那么這樣后,資源的引用路徑就正確了。

當然在config文件夾下的index.js中修改 assetsPublicPath: ’./’同樣也可以達到資源的相對引用。

背景圖片的引用問題

上面雖然解決了資源路徑的引用問題,但是資源里面的背景圖片,不像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 靜態資源路徑 和 style問題

添加如圖所示的一行代碼,這樣不論是字體還是圖片的引用問題都能解決。

以上這篇淺談Vue static 靜態資源路徑 和 style問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: vue
相關文章:
国产综合久久一区二区三区