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!

推薦閱讀: