我正在尝试在React js中显示键值对,但是随后我无法正确显示一些方法。我创建了一个表格小部件,但我没有得到正确的显示
我的桌子小部件
import React from 'react';
function Table(props) {
const {
tablevalue,
} = props
console.log(tablevalue)
return(
<div className="table">
<table className="table table-hover">
<tbody>
{ tablevalue.map((item, value)=> (
Object.entries(item, (key, value) => {
return(
<tr className="table-row">
<th scope="col" key={`tablevalue-${key}`}>{key}</th>
<td key={`tablevalue-${value}`}>{value}</td>
</tr>
)
})))}
</tbody>
</table>
</div>
)
}
export default Table;
app.js
import React, { Fragment } from "react";
import Dropdown from './components/widgets/Dropdown/index'
import Table from './components/widgets/Table/index'
function DropdownTest() {
return (
<h3>
<b>Profit</b>
</h3>
<br />
<Table
tablevalue = {[{key:'Binance' , value: 'Polonix'}, {key:'Profit' , value:'Loss'}]}
/>
</div>
);
}
export default DropdownTest;
我希望以表格形式显示我的输出
您可以使用表头
<tbody>
<tr>
<th>Key</th>
<th>Value</th>
</tr>
{tablevalue.map(({ key, value }) => (
<tr className="table-row">
<td key={`tablevalue-${key}`}>{key}</td>
<td key={`tablevalue-${value}`}>{value}</td>
</tr>
))}
</tbody>
代码
const Table = ({ tablevalue }) => (
<div className="table">
<table className="table table-hover">
<tbody>
<tr>
<th>Key</th>
<th>Value</th>
</tr>
{tablevalue.map(({ key, value }) => (
<tr className="table-row">
<td key={`tablevalue-${key}`}>{key}</td>
<td key={`tablevalue-${value}`}>{value}</td>
</tr>
))}
</tbody>
</table>
</div>
);
const DropdownTest = () => (
<div>
<h3>
<b>Profit</b>
</h3>
<br />
<Table
tablevalue={[
{ key: "Binance", value: "Polonix" },
{ key: "Profit", value: "Loss" }
]}
/>
</div>
);
const rootElement = document.getElementById("root");
ReactDOM.render(
<React.StrictMode>
<DropdownTest />
</React.StrictMode>,
rootElement
);
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
<div id="root"></div>
我还没有看到Object.entries
用这种方式。我通常会在上面使用forEach
:
Object.entries(item).forEach(entry => {
let key = entry[0];
let value = entry[1];
});
虽然性能更高的人会改用for in
,因为Object.entries
创建了一个全新的数组,然后forEach
进行了遍历,这是不必要的:
for (const key in item) {
let value = obj[key];
}
您可以这样操作:
import React from "react";
export default props => {
console.log(props.tablevalue);
const ths = props.tablevalue.map(({ key, value }) => (
<th key={value}>{key}</th>
));
const values = props.tablevalue.map(obj => <td>{obj.value}</td>);
return (
<>
<table>
<tr>{ths}</tr>
<tr>{values}</tr>
</table>
</>
);
};
这里是显示表格的stackblitz。
最终,这完全取决于您希望该表的显示方式,您可以根据需要调整一些内容。
检查此沙箱:https://codesandbox.io/s/goofy-breeze-fdcdr
将Tablel组件更改为如下所示:
import React from "react";
function Table(props) {
const { tablevalue } = props;
return (
<div className="table">
<table className="table table-hover">
<tbody>
<tr>
{Object.keys(tablevalue[0]).map(key => (
<th key={key}>{key}</th>
))}
</tr>
{tablevalue.map(({ key, value }) => (
<tr className="table-row">
<td key={`tablevalue-${key}`}>{key}</td>
<td key={`tablevalue-${value}`}>{value}</td>
</tr>
))}
</tbody>
</table>
</div>
);
}
export default Table;