` element, containing a `` for each key in the object.
+
+```jsx
+function MappedTable({ data, propertyNames }) {
+ let filteredData = data.map(v =>
+ Object.keys(v)
+ .filter(k => propertyNames.includes(k))
+ .reduce((acc, key) => ((acc[key] = v[key]), acc), {})
+ );
+ return (
+
+
+ {propertyNames.map(val => | {val} | )}
+
+
+ {filteredData.map((val, i) => (
+
+ {propertyNames.map(p => | {val[p]} | )}
+
+ ))}
+
+
+ );
+}
+```
+
+```jsx
+const people = [
+ { name: 'John', surname: 'Smith', age: 42 },
+ { name: 'Adam', surname: 'Smith', gender: 'male' }
+];
+const propertyNames = ['name', 'surname', 'age'];
+ReactDOM.render(
+ ,
+ document.getElementById('root')
+);
+```
+
+
+
+
|