這篇文章主要介紹了react項目中引入圖片的方法有哪些,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
因為react其實是通過js的reader函數渲染的頁面,所以直接寫src=“路徑”是無法引入圖片
我們可以像引入模塊一樣引入圖片
import img from './../../../../asset/img/user.png'
需要用下面的方式引入
<img src={require('../images/picture.png')} alt="標簽"/>
1 第一種就是常規的 新建一個css文件,然后就可以直接寫css語法了
.img { background: url('../images/picture.png') 0 0 no-repeat; }
2 第二種就是在react組件中通過變量的方式引入,然后直接將變量賦值給img標簽
// 引入圖片文件 import bg from '../images/bg.png' // 通過字符串拼接的方式定義一個樣式對象 const imgStyle = { width: '100%', height: '500px', backgroundImage: 'url(' + bg + ')', backgroundPosition: 'center 0', backgroundSize: '2045px 472px', backgroundRepeat: 'no-repeat' } class Home extends Component { constructor () { super (props) } render() { // 最后直接將變量賦值給標簽 <div > ... </div> } }
我們也可以將相對路徑用require包裹之后直接賦給src,就像在vue中一樣。
<img width="100" height="100" src={require('./../../../../asset/img/user.png')} alt="" className={'user-img'}/>
**注意:**這里有個問題,因為file-loader庫的版本不同,這里有些細微差別。高版本的file-loader庫esModule默認為true,require返回一個ES模塊而不是字符串路徑。而這個ES模塊的default屬性為字符串路徑,所以應該這樣寫:
<img width="100" height="100" src={require('./../../../../asset/img/user.png').default} alt="" className={'user-img'}/>
我們也不要去糾結我們的file-loader版本到底是多少,當我們直接使用require還是無法正常顯示圖片的時候,我們在require后面加個.default即可。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“react項目中引入圖片的方法有哪些”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。