react-native-swiper的寬度和高度如何設(shè)置

問題:react-native-swiper的寬度和高度怎么設(shè)置庸追?

本文我們將用設(shè)置高度來舉例說明(寬度的設(shè)置可以類比得到)

目標:給Swiper設(shè)置300的高度

初嘗試使用react-native-swiper的同學都知道,react-native-swiper的高度很魔性蜒车。先貼一張官方給的設(shè)置截圖:

官方的高度設(shè)置描述

嘗試去理解If no specify default fullscreen mode by flex:1的意思悔详。

表面上看撞反,就是如果不設(shè)置似扔,就會按照通過flex:1設(shè)置高度逛尚。所以很自然就想到垄惧,給Swiper指定一個高度即可,于是我做了以下嘗試:

render() {
return (
  <View style={{flex:1, backgroundColor: 'gray'}}>
    <Swiper 
      style={{backgroundColor: 'yellow'}}
      height={300}>
      <View style={{backgroundColor: 'green', height: 150}}><Text>1</Text></View>
      <View style={{backgroundColor: 'green', height: 150}}><Text>2</Text></View>
      <View style={{backgroundColor: 'green', height: 150}}><Text>3</Text></View>
      <View style={{backgroundColor: 'green', height: 150}}><Text>4</Text></View>
    </Swiper>
  </View>
)
}

然后你會發(fā)現(xiàn)绰寞,結(jié)果并沒有你認為的那樣到逊,看下面的截圖。

第一次嘗試

然后再仔細品味這句description滤钱,可能你會想到觉壶,設(shè)置flex:0就好了
,于是把上面的設(shè)置修改一下菩暗,給Swiperstyle設(shè)置flex:1掰曾,信心滿滿地保存運行查看效果。

設(shè)置flex:0

通過看顏色可以知道停团,Swiper的灰色背景確實只有300高旷坦,但是Swiper的點卻在最下方,說明Swiper仍然占據(jù)了整個屏幕的寬度佑稠。

當然秒梅,你也可以嘗試在Swiperstyle中設(shè)置高度,這里就不貼代碼了舌胶,我直接給出我測試的結(jié)論捆蜀。Swiper設(shè)置的屬性height,會直接覆蓋style中的height幔嫂,也就是說辆它,如果只設(shè)置style中的height,則style中height生效履恩,如果同時設(shè)置style中的heightSwiper的屬性height锰茉,則Swiper的屬性height生效,style中的height無論設(shè)置什么值都沒有效果切心。
不管是style中的height還是Swiper的屬性height都只是限制了Swiper的背景色高度飒筑,而不是Swiper占據(jù)的整個空間的高度。

通過上面的實驗绽昏,仔細分析你就會發(fā)現(xiàn)协屡,無論怎樣設(shè)置,Swiper的高度始終等于屏幕的高度全谤,而它的本質(zhì)是等于Swiper父組件的高度(當然肤晓,這里的結(jié)論是基于Swiper的父組件只有Swiper一個子組件,如果有其他組件,那就會根據(jù)flex:1來分享父組件剩余的空間)材原。

到這里沸久,已經(jīng)快要接近真相了,假設(shè)我們給Swiper包裹一層View作為父組件(后面簡稱父組件)余蟹,然后設(shè)置父組件的高度卷胯,那么理論上Swiper就會自適應(yīng)父組件,使得Swiper的高度等于父組件的高度威酒。
于是寫下代碼窑睁,做最后的試驗

render() {
return (
  <View style={{flex:1, backgroundColor: 'gray'}}>
    <View style={{height: 300}}>
    <Swiper>
      <View style={{backgroundColor: 'green', height: 150}}><Text>1</Text></View>
      <View style={{backgroundColor: 'green', height: 150}}><Text>2</Text></View>
      <View style={{backgroundColor: 'green', height: 150}}><Text>3</Text></View>
      <View style={{backgroundColor: 'green', height: 150}}><Text>4</Text></View>
    </Swiper>
    </View>
  </View>
)
}
終于成功了!

所以最終方案為:Swiper外面包裹一層View葵孤,通過設(shè)置View的高度担钮,間接設(shè)置Swiper的高度。如下所示:

<View style={{height: 300}}>
  <Swiper>
  //...item省略
  </Swiper>
</View>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末尤仍,一起剝皮案震驚了整個濱河市箫津,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌宰啦,老刑警劉巖苏遥,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異赡模,居然都是意外死亡田炭,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進店門漓柑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來教硫,“玉大人,你說我怎么就攤上這事辆布∷簿兀” “怎么了?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵锋玲,是天一觀的道長丧鸯。 經(jīng)常有香客問我,道長嫩絮,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任围肥,我火速辦了婚禮剿干,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘穆刻。我一直安慰自己置尔,他們只是感情好,可當我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布氢伟。 她就那樣靜靜地躺著榜轿,像睡著了一般幽歼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上谬盐,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天甸私,我揣著相機與錄音,去河邊找鬼飞傀。 笑死皇型,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的砸烦。 我是一名探鬼主播弃鸦,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼幢痘!你這毒婦竟也來了唬格?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤颜说,失蹤者是張志新(化名)和其女友劉穎购岗,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體脑沿,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡藕畔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了庄拇。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片注服。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖措近,靈堂內(nèi)的尸體忽然破棺而出溶弟,到底是詐尸還是另有隱情,我是刑警寧澤瞭郑,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布辜御,位于F島的核電站,受9級特大地震影響屈张,放射性物質(zhì)發(fā)生泄漏擒权。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一阁谆、第九天 我趴在偏房一處隱蔽的房頂上張望碳抄。 院中可真熱鬧,春花似錦场绿、人聲如沸剖效。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽璧尸。三九已至咒林,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間爷光,已是汗流浹背垫竞。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留瞎颗,地道東北人件甥。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像哼拔,于是被迫代替她去往敵國和親引有。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,941評論 2 355