React Native 速成 009 — 即將消失的ListView

我們先來看一下ListView的介紹鸽嫂,這個(gè)組件是不是很高端大氣上檔次边酒!

ListView組件用于顯示一個(gè)垂直的滾動(dòng)列表僚碎,其中的元素之間結(jié)構(gòu)近似而僅數(shù)據(jù)不同。

ListView更適于長列表數(shù)據(jù)抠藕,且元素個(gè)數(shù)可以增刪饿肺。和ScrollView
不同的是,ListView
并不立即渲染所有元素盾似,而是優(yōu)先渲染屏幕上可見的元素敬辣。

ListView組件必須的兩個(gè)屬性是dataSource和renderRow。dataSource是列表的數(shù)據(jù)源颜说,而renderRow則逐個(gè)解析數(shù)據(jù)源中的數(shù)據(jù),然后返回一個(gè)設(shè)定好格式的組件來渲染汰聋。

下面的例子創(chuàng)建了一個(gè)簡單的ListView门粪,并預(yù)設(shè)了一些模擬數(shù)據(jù)。首先是初始化ListView所需的dataSource烹困,其中的每一項(xiàng)(行)數(shù)據(jù)之后都在renderRow中被渲染成了Text組件玄妈,最后構(gòu)成整個(gè)ListView。

rowHasChanged函數(shù)也是ListView的必需屬性髓梅。這里我們只是簡單的比較兩行數(shù)據(jù)是否是同一個(gè)數(shù)據(jù)(===符號(hào)只比較基本類型數(shù)據(jù)的值拟蜻,和引用類型的地址)來判斷某行數(shù)據(jù)是否變化了。

然而 ListView 快要被打入冷宮了枯饿。

https://hackernoon.com/react-native-new-flatlist-component-30db558c7a5b

取代 ListView 的新歡們分別有 FlatList*, SectionList, VirtualizedList, and *VirtualizedSectionList

FlatList

默認(rèn)情況下酝锅,F(xiàn)latList 希望你的數(shù)據(jù)源是一個(gè)數(shù)組。它API一個(gè)巨大好處是能讓你自己實(shí)現(xiàn) getItem奢方。這樣對(duì)非標(biāo)的數(shù)據(jù)格式非常有用搔扁,如不可變數(shù)據(jù)或復(fù)雜的嵌套數(shù)據(jù)爸舒。

如何從 ListView 到 FlatView

Let's see!

-import { Text, View, ListView } from 'react-native';
+import { Text, View } from 'react-native';
+import FlatList from 'react-native/Libraries/Lists/FlatList';

 import style from './styles';
 import listData from './listData';

 class App extends Component {

-  constructor(props) {
-    super(props);
-
-    const dataSource = new ListView.DataSource({
-      rowHasChanged: (r1, r2) => r1 !== r2,
-      sectionHeaderHasChanged: (s1, s2) => s1 !== s2,
-    });
-
-    this.state = {
-      dataSource: dataSource.cloneWithRowsAndSections(listData),
-    };
-  }
-
-  componentWillReceiveProps(newProps) {
-    this.setState({
-      dataSource: this.state.dataSource.cloneWithRows(newProps.listData),
-    });
-  }
-
-  renderRow(rowData) {
-    return <Text style={style.row}>{rowData}</Text>;
+  renderItem({ item, index }) {
+    return <Text style={style.row}>{item}</Text>;
   }

  render() {
    return (
      <View style={style.container}>
         <Text style={style.welcome}>
           Welcome to React Native!
         </Text>
-        <ListView
-          dataSource={this.state.dataSource}
-          renderRow={this.renderRow}
+        <FlatList
+          data={listData}
+          renderItem={this.renderItem}
         />
      </View>
    );
  }

}

是不是代碼行數(shù)大大減少?

唯一要注意的是稿蹲,默認(rèn)導(dǎo)入的react-native包沒有這些扭勉,這些組件是在 master 倉庫下,所以我們需要以下代碼來獲取他們:

mkdir -p node_modules/react-native/Libraries/Lists/ && \
for file in 'FlatList' 'MetroListView' 'SectionList' 'VirtualizedList' 'VirtualizedSectionList' 'ViewabilityHelper' 'VirtualizeUtils'; \
  do curl https://raw.githubusercontent.com/facebook/react-native/master/Libraries/Lists/${file}.js > node_modules/react-native/Libraries/Lists/${file}.js; \
  done

這些代碼會(huì)下載最新版本的FlatList和依賴到node_modules目錄苛聘。然后你就可以像上面的例子那樣引入了涂炎。

更詳細(xì)的示例可以參考 FlatListExampleexample app

下一課結(jié)合 networking 和 flatlist 我們來顯示數(shù)據(jù)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末设哗,一起剝皮案震驚了整個(gè)濱河市唱捣,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌熬拒,老刑警劉巖爷光,帶你破解...
    沈念sama閱讀 211,348評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異澎粟,居然都是意外死亡蛀序,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門活烙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來徐裸,“玉大人,你說我怎么就攤上這事啸盏≈睾兀” “怎么了?”我有些...
    開封第一講書人閱讀 156,936評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵回懦,是天一觀的道長气笙。 經(jīng)常有香客問我,道長怯晕,這世上最難降的妖魔是什么潜圃? 我笑而不...
    開封第一講書人閱讀 56,427評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮舟茶,結(jié)果婚禮上谭期,老公的妹妹穿的比我還像新娘。我一直安慰自己吧凉,他們只是感情好隧出,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,467評(píng)論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著阀捅,像睡著了一般胀瞪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上饲鄙,一...
    開封第一講書人閱讀 49,785評(píng)論 1 290
  • 那天赏廓,我揣著相機(jī)與錄音涵紊,去河邊找鬼。 笑死幔摸,一個(gè)胖子當(dāng)著我的面吹牛摸柄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播既忆,決...
    沈念sama閱讀 38,931評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼驱负,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了患雇?” 一聲冷哼從身側(cè)響起跃脊,我...
    開封第一講書人閱讀 37,696評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎苛吱,沒想到半個(gè)月后酪术,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,141評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡翠储,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,483評(píng)論 2 327
  • 正文 我和宋清朗相戀三年绘雁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片援所。...
    茶點(diǎn)故事閱讀 38,625評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡庐舟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出住拭,到底是詐尸還是另有隱情挪略,我是刑警寧澤,帶...
    沈念sama閱讀 34,291評(píng)論 4 329
  • 正文 年R本政府宣布滔岳,位于F島的核電站杠娱,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏谱煤。R本人自食惡果不足惜摊求,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,892評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望趴俘。 院中可真熱鬧睹簇,春花似錦奏赘、人聲如沸寥闪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽疲憋。三九已至,卻和暖如春梁只,著一層夾襖步出監(jiān)牢的瞬間缚柳,已是汗流浹背埃脏。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留秋忙,地道東北人彩掐。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像灰追,于是被迫代替她去往敵國和親堵幽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,492評(píng)論 2 348

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