react 項目中引入圖片的幾種方式
img標簽引入圖片
因為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 style="imgStyle"> ... </div> } }
require
我們也可以將相對路徑用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 項目中引入圖片的幾種方式的文章就介紹到這瞭,更多相關react 引入圖片內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 基於CSS實現MaterialUI按鈕點擊動畫並封裝成 React 組件
- react中JSX的註意點詳解
- 在vue中如何引入外部的css文件
- React實現類似於Vue中的插槽的項目實踐
- react實現導航欄二級聯動