内容简介:对原作这里学习第一节,Array,即把数组数据渲染为列表、表格。通过数组渲染元素列表。
对原作 30-seconds-of-react 项目的中文化与学习,并对案例进行分析、运行和注释。 中文项目地址: 30-seconds-of-react-zh_CN-with-demo 。
这里学习第一节,Array,即把数组数据渲染为列表、表格。
DataList渲染为列表
通过数组渲染元素列表。
-
使用
isOrdered
prop 的值有条件地渲染<ol>
或<ul>
列表。 -
使用
Array.prototype.map
将data
中的每个项目渲染为<li>
元素,给它一个由其索引和值的串联产生的key
。 -
默认情况下,省略
isOrdered
prop 以渲染<ul>
列表。
function DataList({ isOrdered, data }) { const list = data.map((val, i) => <li key={`${i}_${val}`}>{val}</li>); return isOrdered ? <ol>{list}</ol> : <ul>{list}</ul>; } 复制代码
export default function() { const names = ['John', 'Paul', 'Mary']; return ( <div> 无序列表: <DataList data={names} /> 有序列表: <DataList data={names} isOrdered /> </div> ); } 复制代码
ps:
DataTable渲染为表格
通过数组渲染表格,动态创建每一行。
*渲染一个带有两列( ID
和 Value
)的 <table>
元素。
*使用 Array.prototype.map
将 data
中的每个项目渲染为 <tr>
元素,由其索引和值组成,给它一个由两者串联产生的 key
。
function DataTable({ data }) { return ( <table> <thead> <tr> <th>ID</th> <th>Value</th> </tr> </thead> <tbody> {data.map((val, i) => ( <tr key={`${i}_${val}`}> <td>{i}</td> <td>{val}</td> </tr> ))} </tbody> </table> ); } 复制代码
export default function() { const people = ['John', 'Jesse']; return <DataTable data={people} />; } 复制代码
ps:
MappedTable渲染为映射表格
通过对象数组渲染表格,属性名称与列对应,动态创建每一行。
-
使用
Object.keys()
,Array.prototype.filter()
,Array.prototype.includes()
和Array.prototype.reduce()
生成一个filteredData
数组,包含所有对象 使用propertyNames
中指定的键。 -
渲染一个
<table>
元素,其中一组列等于propertyNames
中的值。 -
使用
Array.prototype.map
将propertyNames
数组中的每个值渲染为<th>
元素。 -
使用
Array.prototype.map
将filteredData
数组中的每个对象渲染为<tr>
元素,对象中的每个键包含一个<td>
。
function MappedTable({ data, propertyNames }) { let filteredData = data.map(v => Object.keys(v) .filter(k => propertyNames.includes(k)) // 迭代为 acc 对象赋值: // 回调函数为 (acc, key) => ((acc[key] = v[key]), acc) 初始值为 {} // ((操作), 返回值) 语法解读:括号里进行任意操作,并指定返回值 .reduce(( acc, key) => ((acc[key] = v[key]), acc), {}), ); return ( <table> <thead> <tr> {propertyNames.map(val => ( <th key={`h_${val}`}>{val}</th> ))} </tr> </thead> <tbody> {filteredData.map((val, i) => ( <tr key={`i_${i}`}> {propertyNames.map(p => ( <td key={`i_${i}_${p}`}>{val[p]}</td> ))} </tr> ))} </tbody> </table> ); } 复制代码
Notes
此组件不适用于嵌套对象,如果在 propertyNames
中指定的任何属性中有嵌套对象,则会中断。
export default function() { const people = [ { name: 'John', surname: 'Smith', age: 42 }, { name: 'Adam', surname: 'Smith', gender: 'male' }, ]; const propertyNames = ['name', 'surname', 'age']; return <MappedTable data={people} propertyNames={propertyNames} />; } 复制代码
ps:
以上所述就是小编给大家介绍的《使用 React 把数组数据渲染为列表、表格》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Octane渲染入门-渲染设置图文版
- C语言指针数组和数组指针
- 数组 – 如何在Swift中将数组拆分成两半?
- 菜鸡的算法修炼:数组(旋转数组的最小数字)
- 交换数组元素,使得数组的和的差最小
- JS数组专题1️⃣ ➖ 数组扁平化
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Algorithms to Live By
Brian Christian、Tom Griffiths / Henry Holt and Co. / 2016-4-19 / USD 30.00
A fascinating exploration of how insights from computer algorithms can be applied to our everyday lives, helping to solve common decision-making problems and illuminate the workings of the human mind ......一起来看看 《Algorithms to Live By》 这本书的介绍吧!