06 React Native常用組件之Image

(申明: 此系列教程,轉(zhuǎn)載旋之華微信公眾號(hào),如有侵權(quán) . 通知?jiǎng)h除~)

(大家可以添加他的微信公眾號(hào)了解更多內(nèi)容.)

image.png

一、前言

 在開(kāi)發(fā)中還有一個(gè)非常重要的組件Image,通過(guò)這個(gè)組件可以展示各種各樣的圖片幅狮,而且在React Native中該組件可以通過(guò)多種方式加載圖片資源。

二瓶埋、Image組件的基本用法

2.1 從當(dāng)前項(xiàng)目中加載圖片

<View style={styles.container}>

    <Text style={styles.textMarginTop}>加載本地的圖片</Text>

    <Image source={require('./img/2.png')} style={{width: 120, height: 120}}  />

 </View>

  該圖片資源文件的查找和JS模塊相似篮愉,該會(huì)根據(jù)填寫(xiě)的圖片路徑相對(duì)于當(dāng)前的js文件路徑進(jìn)行搜索。

 此外集侯,React Naive的Packager會(huì)根據(jù)平臺(tái)選擇相應(yīng)的文件矫付,例如:my_icon.ios.png和my_icon.android.png兩個(gè)文件(命名方式android或者ios),會(huì)分別根據(jù)android或者ios平臺(tái)選擇相應(yīng)的文件溜族。

2.2 加載使用APP中的圖片

<View style={styles.container}>

   <Text style={styles.textMarginTop}>加載Xcode中的圖片</Text>

   <Image source={require('image!icon_homepage_map')} style={{width: 50,height:50}}/>

</View>

 使用已經(jīng)打包在APP中的圖片資源(例如:xcode asset文件夾以及Android drawable文件夾)

2.3 加載來(lái)自網(wǎng)絡(luò)的圖片

   客戶(hù)端的很多圖片資源基本上都是實(shí)時(shí)通過(guò)網(wǎng)絡(luò)進(jìn)行獲取的冗酿,寫(xiě)法和上面的加載本地資源圖片的方式不太一樣,

這邊一定需要指定圖片的尺寸大小

术健,實(shí)現(xiàn)如下:

<View style={styles.container}>

    <Image source={{uri:'https://www.baidu.com/img/bd_logo1.png'}} style={{flex:1,width:200, height:100, resizeMode: Image.resizeMode.cover}}/>

    <Image source={{uri:'https://www.baidu.com/img/bd_logo1.png'}} style={{flex:1,width:200, height:100, resizeMode: Image.resizeMode.contain}}/>

    <Image source={{uri:'https://www.baidu.com/img/bd_logo1.png'}} style={{flex:1,width:200, height:100, resizeMode: Image.resizeMode.stretch}}>

</View>

細(xì)心的同學(xué)可能已經(jīng)注意到汹碱,我在上面用到了resizeMode這樣一個(gè)屬性,那么這個(gè)屬性的作用相當(dāng)于OC中設(shè)置圖片的內(nèi)容模式荞估。

Image.resizeMode.cover:圖片居中顯示咳促,沒(méi)有被拉伸,超出部分被截?cái)啵?/strong>

Image.resizeMode.contain:容器完全容納圖片勘伺,圖片等比例進(jìn)拉伸跪腹;

Image.resizeMode.stretch: 圖片被拉伸適應(yīng)容器大小,有可能會(huì)發(fā)生變形飞醉。

2.4 設(shè)置圖片為背景

<Image source={{uri:'https://www.baidu.com/img/bd_logo1.png'}} style={{flex:1,width:200, height:100, resizeMode: Image.resizeMode.stretch}}>

       <Text style={{marginTop: 60, backgroundColor: 'red'}}>下面是背景圖片</Text>

</Image>

運(yùn)行的效果:

image

三冲茸、Image組件的常見(jiàn)屬性

3.1 屬性方法

**onLayout(function)** 

當(dāng)Image布局發(fā)生改變的,會(huì)進(jìn)行調(diào)用該方法缅帘,調(diào)用的代碼為:{nativeEvent: {layout: {x, y, width, height}}}.

onLoad (function)

當(dāng)圖片加載成功之后轴术,回調(diào)該方法

onLoadEnd (function)

當(dāng)圖片加載失敗回調(diào)該方法,該不會(huì)管圖片加載成功還是失敗

**onLoadStart (fcuntion)** 

當(dāng)圖片開(kāi)始加載的時(shí)候調(diào)用該方法

**resizeMode** 

縮放比例,可選參數(shù)('cover', 'contain', 'stretch') 該當(dāng)圖片的尺寸超過(guò)布局的尺寸的時(shí)候钦无,會(huì)根據(jù)設(shè)置Mode進(jìn)行縮放或者裁剪圖片

source{uri:string}

進(jìn)行標(biāo)記圖片的引用逗栽,該參數(shù)可以為一個(gè)網(wǎng)絡(luò)url地址或者一個(gè)本地的路徑

3.2 樣式風(fēng)格屬性

FlexBox 支持彈性盒子風(fēng)格

Transforms 支持屬性動(dòng)畫(huà)

backgroundColor 背景顏色

borderColor 邊框顏色

borderWidth 邊框?qū)挾?/p>

borderRadius 邊框圓角

overflow 設(shè)置圖片尺寸超過(guò)容器可以設(shè)置顯示或者隱藏('visible','hidden')

tintColor 顏色設(shè)置

opacity 設(shè)置不透明度0.0(透明)-1.0(完全不透明)

** 四、Image組件的小練習(xí)**

   通過(guò)一款包包的展示失暂,總結(jié)前面所學(xué)的View彼宠,Text和今天的Image組件鳄虱,具體代碼如下:
image
image
image

運(yùn)行效果如下:

image
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市凭峡,隨后出現(xiàn)的幾起案子拙已,更是在濱河造成了極大的恐慌,老刑警劉巖摧冀,帶你破解...
    沈念sama閱讀 222,807評(píng)論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件倍踪,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡按价,警方通過(guò)查閱死者的電腦和手機(jī)惭适,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,284評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)楼镐,“玉大人癞志,你說(shuō)我怎么就攤上這事】虿” “怎么了凄杯?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,589評(píng)論 0 363
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)秉宿。 經(jīng)常有香客問(wèn)我戒突,道長(zhǎng),這世上最難降的妖魔是什么描睦? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,188評(píng)論 1 300
  • 正文 為了忘掉前任膊存,我火速辦了婚禮,結(jié)果婚禮上忱叭,老公的妹妹穿的比我還像新娘隔崎。我一直安慰自己,他們只是感情好韵丑,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,185評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布爵卒。 她就那樣靜靜地躺著,像睡著了一般撵彻。 火紅的嫁衣襯著肌膚如雪钓株。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,785評(píng)論 1 314
  • 那天陌僵,我揣著相機(jī)與錄音轴合,去河邊找鬼。 笑死碗短,一個(gè)胖子當(dāng)著我的面吹牛值桩,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播豪椿,決...
    沈念sama閱讀 41,220評(píng)論 3 423
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼奔坟,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了搭盾?” 一聲冷哼從身側(cè)響起咳秉,我...
    開(kāi)封第一講書(shū)人閱讀 40,167評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎鸯隅,沒(méi)想到半個(gè)月后澜建,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,698評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蝌以,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,767評(píng)論 3 343
  • 正文 我和宋清朗相戀三年炕舵,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片跟畅。...
    茶點(diǎn)故事閱讀 40,912評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡咽筋,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出徊件,到底是詐尸還是另有隱情奸攻,我是刑警寧澤,帶...
    沈念sama閱讀 36,572評(píng)論 5 351
  • 正文 年R本政府宣布虱痕,位于F島的核電站睹耐,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏部翘。R本人自食惡果不足惜硝训,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,254評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望新思。 院中可真熱鬧窖梁,春花似錦、人聲如沸表牢。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,746評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)崔兴。三九已至彰导,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間敲茄,已是汗流浹背位谋。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,859評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留堰燎,地道東北人掏父。 一個(gè)月前我還...
    沈念sama閱讀 49,359評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像秆剪,于是被迫代替她去往敵國(guó)和親赊淑。 傳聞我的和親對(duì)象是個(gè)殘疾皇子爵政,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,922評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容