react 項(xiàng)目中引入圖片的幾種方式
img標(biāo)簽引入圖片
因?yàn)閞eact其實(shí)是通過(guò)js的reader函數(shù)渲染的頁(yè)面,所以直接寫(xiě)src=“路徑”是無(wú)法引入圖片
我們可以像引入模塊一樣引入圖片
import img from './../../../../asset/img/user.png'
需要用下面的方式引入
<img src={require('../images/picture.png')} alt="標(biāo)簽"/>
背景圖片引入
1 第一種就是常規(guī)的 新建一個(gè)css文件,然后就可以直接寫(xiě)css語(yǔ)法了
.img { background: url('../images/picture.png') 0 0 no-repeat; }
2 第二種就是在react組件中通過(guò)變量的方式引入,然后直接將變量賦值給img標(biāo)簽
// 引入圖片文件 import bg from '../images/bg.png' // 通過(guò)字符串拼接的方式定義一個(gè)樣式對(duì)象 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
我們也可以將相對(duì)路徑用require包裹之后直接賦給src,就像在vue中一樣。
<img width="100" height="100" src={require('./../../../../asset/img/user.png')} alt="" className={'user-img'}/>
**注意:**這里有個(gè)問(wèn)題,因?yàn)閒ile-loader庫(kù)的版本不同,這里有些細(xì)微差別。高版本的file-loader庫(kù)esModule默認(rèn)為true,require返回一個(gè)ES模塊而不是字符串路徑。而這個(gè)ES模塊的default屬性為字符串路徑,所以應(yīng)該這樣寫(xiě):
<img width="100" height="100" src={require('./../../../../asset/img/user.png').default} alt="" className={'user-img'}/>
我們也不要去糾結(jié)我們的file-loader版本到底是多少,當(dāng)我們直接使用require還是無(wú)法正常顯示圖片的時(shí)候,我們?cè)趓equire后面加個(gè).default即可
到此這篇關(guān)于react 項(xiàng)目中引入圖片的幾種方式的文章就介紹到這了,更多相關(guān)react 引入圖片內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
webpack4 + react 搭建多頁(yè)面應(yīng)用示例
這篇文章主要介紹了webpack4 + react 搭建多頁(yè)面應(yīng)用示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08react路由跳轉(zhuǎn)傳參刷新頁(yè)面后參數(shù)丟失的解決
這篇文章主要介紹了react路由跳轉(zhuǎn)傳參刷新頁(yè)面后參數(shù)丟失的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06react實(shí)現(xiàn)頁(yè)面水印效果的全過(guò)程
大家常常關(guān)注的是網(wǎng)站圖片增加水印,而很少關(guān)注頁(yè)面水印,其實(shí)這個(gè)需求也是比較常見(jiàn)的,比如公文系統(tǒng)、合同系統(tǒng)等,這篇文章主要給大家介紹了關(guān)于react實(shí)現(xiàn)頁(yè)面水印效果的相關(guān)資料,需要的朋友可以參考下2021-09-09React如何通過(guò)@craco/craco代理接口
這篇文章主要介紹了React如何通過(guò)@craco/craco代理接口問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10React Router6.x路由表封裝的兩種寫(xiě)法
本文主要介紹了React Router6.x路由表封裝的兩種寫(xiě)法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01