美文网首页
Day5 如何使用长列表/网络

Day5 如何使用长列表/网络

作者: 十旋转45度 | 来源:发表于2017-11-23 16:59 被阅读0次

如何使用长列表

React Native提供了几个适用于展示长列表数据的组件,一般而言我们会选用FlatList或是SectionList

FlatList组件用于显示一个垂直的滚动列表,其中的元素之间结构近似而仅数据不同。

FlatList更适于长列表数据,且元素个数可以增删。和ScrollView不同的是,FlatList并不立即渲染所有元素,而是优先渲染屏幕上可见的元素。

FlatList组件必须的两个属性是datarenderItemdata是列表的数据源,而renderItem则从数据源中逐个解析数据,然后返回一个设定好格式的组件来渲染。

import React, { Component }  from 'react';
import {StyleSheet,Text, FlatList,View} from 'react-native';

export default class FlatListBasics extends Component {
  render() {
    return (
      <View style={styles.container}>
        <FlatList
          data={[
            {key: 'Devin'},
            {key: 'Jackson'},
            {key: 'James'},
            {key: 'Joel'},
            {key: 'John'},
            {key: 'Jillian'},
            {key: 'Jimmy'},
            {key: 'Julie'},
          ]}
          renderItem={({item}) => <Text style={styles.item}>{item.key}</Text>}
        />
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
   flex: 1,
   paddingTop: 22
  },
  item: {
    padding: 10,
    fontSize: 18,
    height: 44,
  },
})

如果要渲染的是一组分组的数据,比如带个分组标签的, 那么SectionList将是个良好的选择.

export default class SectionListBasics extends Component {
  render() {
    return (
      <View style={styles.container}>
        <SectionList
          sections={[
            {title: 'D', data: ['Devin']},
            {title: 'J', data: ['Jackson', 'James', 'Jillian', 'Jimmy', 'Joel', 'John', 'Julie']},
          ]}
          renderItem={({item}) => <Text style={styles.item}>{item}</Text>}
          renderSectionHeader={({section}) => <Text style={styles.sectionHeader}>{section.title}</Text>}
        />
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
   flex: 1,
   paddingTop: 22
  },
  sectionHeader: {
    paddingTop: 2,
    paddingLeft: 10,
    paddingRight: 10,
    paddingBottom: 2,
    fontSize: 14,
    fontWeight: 'bold',
    backgroundColor: 'rgba(247,247,247,1.0)',
  },
  item: {
    padding: 10,
    fontSize: 18,
    height: 44,
  },
})

网络

发起网络请求
fetch('https://mywebsite.com/mydata.json')
fetch('https://mywebsite.com/endpoint/', {
  method: 'POST',
  headers: {
    'Accept': 'application/json',
    'Content-Type': 'application/json',
  },
  body: JSON.stringify({
    firstParam: 'yourValue',
    secondParam: 'yourOtherValue',
  })
})
fetch('https://mywebsite.com/endpoint/', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/x-www-form-urlencoded',
  },
  body: 'key1=value1&key2=value2'
})
处理服务器的响应数据

网络请求天然是一种异步操作

getMoviesFromApiAsync() {
    return fetch('https://facebook.github.io/react-native/movies.json')
      .then((response) => response.json())
      .then((responseJson) => {
        return responseJson.movies;
      })
      .catch((error) => {
        console.error(error);
      });
  }

ES7标准中的async/await 语法:

 // 注意这个方法前面有async关键字
  async getMoviesFromApi() {
    try {
      // 注意这里的await语句,其所在的函数必须有async关键字声明
      let response = await fetch('https://facebook.github.io/react-native/movies.json');
      let responseJson = await response.json();
      return responseJson.movies;
    } catch(error) {
      console.error(error);
    }
  }
使用其他的网络库

React Native中已经内置了XMLHttpRequest API(也就是俗称的ajax)。一些基于XMLHttpRequest封装的第三方库也可以使用,例如frisbee或是axios等。但注意不能使用jQuery,因为jQuery中还使用了很多浏览器中才有而RN中没有的东西(所以也不是所有web中的ajax库都可以直接使用)。

WebSocket支持
var ws = new WebSocket('ws://host.com/path');

ws.onopen = () => {
  // 打开一个连接

  ws.send('something'); // 发送一个消息
};

ws.onmessage = (e) => {
  // 接收到了一个消息
  console.log(e.data);
};

ws.onerror = (e) => {
  // 发生了一个错误
  console.log(e.message);
};

ws.onclose = (e) => {
  // 连接被关闭了
  console.log(e.code, e.reason);
};

相关文章

  • Day5 如何使用长列表/网络

    如何使用长列表 React Native提供了几个适用于展示长列表数据的组件,一般而言我们会选用FlatList或...

  • 学习小组Day2笔记--Mengshangsen

    ls输出的是横向的列表,怎样输出长格式列表(提示:搜索ls) 如何查看长格式列表中文件的大小?(提示:ls) 查看...

  • 学习小组Day2--扩展

    ls输出的是横向的列表,怎样输出长格式列表(提示:搜索ls)如何查看长格式列表中文件的大小?(提示:ls)查看Li...

  • HTML4

    有序列表、无序列表、自定义列表如何使用?写个简单的例子。三者在语义上有什么区别?哪些情况下使用那种?如何嵌套? 有...

  • HTML4

    有序列表、无序列表、自定义列表如何使用?如何嵌套?写个简单的例子。三者在语义上有什么区别?在哪些情况下使用哪种(重...

  • python开发--列表&元组

    如何高效地处理列表中的元素;如何使用for 循环遍历列表,Python如何根据缩进来确定程序的结构以及如何避免一些...

  • 学习小组Day2笔记--点点滴滴

    召唤Linux 课后作业 怎样输出长格式列表 ls -1如何查看长格式列表中文件的大小 ls-lh 查看系统版...

  • python编程学习Day3 前4章总结

    第4章 学习内容 如何高效地处理列表中的元素;如何使用for循环遍历列表,Python如何根据缩进来确定程序的结构...

  • 压箱底的干货!干货!——Redis面试系列(二)

    Redis 如何做内存优化? 答:尽可能使用散列表(hashes),散列表(是说散列表里面存储的数少)使用的内存非...

  • Python之集合筛选

    如何在列表,字典,集合中根据条件筛选 核心:使用生成式 列表: 生成随机列表: 筛选方法: 字典: 生成字典: 筛...

网友评论

      本文标题:Day5 如何使用长列表/网络

      本文链接:https://www.haomeiwen.com/subject/mgtzvxtx.html