react 項目中引入圖片的幾種方式
img標(biāo)簽引入圖片
因為react其實是通過js的reader函數(shù)渲染的頁面,所以直接寫src=“路徑”是無法引入圖片
我們可以像引入模塊一樣引入圖片
import img from './../../../../asset/img/user.png'
需要用下面的方式引入
<img src={require('../images/picture.png')} alt="標(biāo)簽"/>
背景圖片引入
1 第一種就是常規(guī)的 新建一個css文件,然后就可以直接寫css語法了
.img { background: url('../images/picture.png') 0 0 no-repeat; }
2 第二種就是在react組件中通過變量的方式引入,然后直接將變量賦值給img標(biāo)簽
// 引入圖片文件 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() { // 最后直接將變量賦值給標(biāo)簽 <div style="imgStyle"> ... </div> } }
require
我們也可以將相對路徑用require包裹之后直接賦給src,就像在vue中一樣。
<img width="100" height="100" src={require('./../../../../asset/img/user.png')} alt="" className={'user-img'}/>
**注意:**這里有個問題,因為file-loader庫的版本不同,這里有些細(xì)微差別。高版本的file-loader庫esModule默認(rèn)為true,require返回一個ES模塊而不是字符串路徑。而這個ES模塊的default屬性為字符串路徑,所以應(yīng)該這樣寫:
<img width="100" height="100" src={require('./../../../../asset/img/user.png').default} alt="" className={'user-img'}/>
我們也不要去糾結(jié)我們的file-loader版本到底是多少,當(dāng)我們直接使用require還是無法正常顯示圖片的時候,我們在require后面加個.default即可
到此這篇關(guān)于react 項目中引入圖片的幾種方式的文章就介紹到這了,更多相關(guān)react 引入圖片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
webpack4 + react 搭建多頁面應(yīng)用示例
這篇文章主要介紹了webpack4 + react 搭建多頁面應(yīng)用示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08react路由跳轉(zhuǎn)傳參刷新頁面后參數(shù)丟失的解決
這篇文章主要介紹了react路由跳轉(zhuǎn)傳參刷新頁面后參數(shù)丟失的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06