gpt4 book ai didi

javascript - 在嵌套字段上进行 react 引导表搜索

转载 作者:行者123 更新时间:2023-11-29 10:07:37 26 4
gpt4 key购买 nike

您好,我正在使用 react-bootstrap-table 模块在我的页面中显示一些数据,我想使用搜索功能按特定列过滤结果。这是我的渲染函数的片段:

render() {
function showOSName(cell, row) {
return cell.name;
}

function showBatteryCondition(cell, row) {
return cell.condition;
}

var selectRowProp = {
mode: "checkbox",
bgColor: "rgb(204, 230, 255)"
};

var tableOptions = {
sizePerPage: 5,
deleteText: "✗ Delete Selected",
paginationSize: 3,
clearSearch: true
};

return (
<BootstrapTable
data={this.state.data.systems}
striped={true}
hover={true}
pagination={true}
selectRow={selectRowProp}
deleteRow={true}
multiColumnSearch={true}
search={true}
ignoreSinglePage={true}
options={tableOptions}
>
<TableHeaderColumn dataField="_id" isKey={true} dataAlign="center"
dataSort={true} searchable={false}>ID</TableHeaderColumn>
<TableHeaderColumn dataField="model" dataAlign="center"
dataSort={true}>Model</TableHeaderColumn>
<TableHeaderColumn dataField="serialnumber" dataAlign="center"
searchable={false}>Serial Number</TableHeaderColumn>
<TableHeaderColumn dataField="os" dataAlign="center" dataSort={true}
dataFormat={showOSName}>OS</TableHeaderColumn>
<TableHeaderColumn dataField="battery" dataAlign="center" dataSort={true}
dataFormat={showBatteryCondition}>Battery Condition</TableHeaderColumn>
</BootstrapTable>
)
}

OS 和 Battery Condition 字段是嵌套值,如下所示:

(示例数据)

id:           "ABC123"
model: "modelName"
serialnumber: "1223334444"
os: {
name: "Linux"
}
battery: {
condition: "Good"
}

我使用 dataFormat 属性在这些列中显示我需要的信息。我还希望能够按以下列进行搜索:型号、操作系统和电池状况。当我按模型搜索时,一切正常,但每当我尝试按嵌套字段进行过滤时,它都不会产生任何结果。谁能帮我吗?谢谢!

最佳答案

我能够通过向每一列添加一个 filterValue 属性并传递我用于 dataFormat 的相同函数来做到这一点。

function filterFunction(cell, row) {
// just return type for filtering or searching.
return cell.type;
}

// add this attribute to TableHeaderColumn: filterValue={ filterFunction }

关于javascript - 在嵌套字段上进行 react 引导表搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40349393/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com