javascript - 完成多次迭代以创建通用过滤器

标签 javascript reactjs code-reuse

我正在尝试开发一个通用过滤器组件,它可以有许多字段来过滤,例如颜色, 尺寸、价格范围等,每个字段可能有不同类型的元素,例如颜色可能有 复选框、单选按钮和价格范围可能有输入元素、下拉菜单等。为了支持这些不同的 在这种情况下,我尝试采用这种模式,但在这里我必须多次迭代相同的事情。

我不确定这个数据结构。如果有人有建议请帮助我改进这段代码但是 这里的主要问题是“多次迭代”。我该如何改进这段代码?

const filterParams = {
  field: {
    id     : 1, label  : 'Field', content: <FieldFilter />
  },
  employee: {
    id     : 1, label  : 'Employee', content: <Employee />
  }
}

<Filter filterParams={filterParams} activeFilterParam="field" />
const Filter = ({ filterParams, activeFilterParam }) => {
  const [show, setShow]=useState(false)
  return (
    <>
      <Button secondary icon={filter} onClick={() => setShow(!show)}>Filter</Button>
      {show && (
        <Card style={{ marginTop: 10 }}>
          <Card.Content>
            <Tabs activeTab={activeFilterParam}>
              <Tabs.List
                render={() => {
                  return (
                    Object.keys(filterParams).map(filterParam => {
                      return (
                        <Tabs.Tab key={filterParam} id={filterParam}>{filterParams[filterParam].label}</Tabs.Tab>
                      )
                    }))
                }} />
              <Tabs.Panels>
                {Object.keys(filterParams).map(filterParam => {
                  return (
                    <Tabs.Panel key={filterParam} panelId={filterParam}>{filterParams[filterParam].content}</Tabs.Panel>
                  )
                })}
              </Tabs.Panels>
            </Tabs>
          </Card.Content>
          <Card.Footer>
            <Button>
              <Button.Content style={{ marginRight: 10 }}>Save</Button.Content>
              <Button.Content secondary onClick={()=>setShow(!show)}>Cancel</Button.Content>
            </Button>
          </Card.Footer>
        </Card>
      )}
    </>
  )
}

最佳答案

如果您不喜欢多次调用 Object.keys(filterParams).map,您可以将循环移至组件函数的顶部。像下面这样的东西可能会起作用:

const Filter = ({ filterParams, activeFilterParam }) => {
  const [show, setShow]=useState(false)

  const {tabs, panels} = Object.keys(filterParams)
    .reduce((acc, filterParam) => {
      acc.tabs.push(
        <Tabs.Tab key={filterParam} id={filterParam}>{filterParams[filterParam].label}</Tabs.Tab>
      );
      acc.panels.push(
        <Tabs.Panel key={filterParam} panelId={filterParam}>{filterParams[filterParam].content}</Tabs.Panel>
      );
      return acc;
    }, { tabs: [], panels: [] });

  return (
    ...
        <Card style={{ marginTop: 10 }}>
          <Card.Content>
            <Tabs activeTab={activeFilterParam}>
              <Tabs.List render={() => tabs} />
              <Tabs.Panels>
                {panels}
              </Tabs.Panels>
            </Tabs>
            ...
        </Card>
    ...
  )
}

请注意,我还没有运行过这个 - 它可能不太正确,但应该给出总体思路......

关于javascript - 完成多次迭代以创建通用过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56335024/

相关文章:

javascript - 自定义指令中范围对象内的嵌套对象

javascript - 如何停止提交输入中的空字段

javascript - ReplaceReducer 导致意外的键错误

reactjs - 与未转换为 localIdentName 的 Storybook 连接字符串 react

swift - 将 UITableViewCell 的 IBOutlet 与两个不同的 UITableViewController 重用

java - 获取数据到回调方法

javascript - 圈子的入口动画

javascript - 数据到达 Controller 但不查看

reactjs - Redux 表单 - 页面加载时未设置初始值

java - 如何构建Java代码以供重用?