React材料ui表无法从行中获取元素

时间:2016-04-15 20:39:44

标签: reactjs material-ui

我想使用材料ui库中的表进行反应: http://www.material-ui.com/#/components/table

我显示它,它运行得很好,我试图获得与我选择的行相关联的对象,但我找不到这样做的方法,我看到了属性children或{{ 1}}但我不能在这里得到我的对象是y代码。 如何获取所选行的整个对象?

onRowSelection

4 个答案:

答案 0 :(得分:6)

  

更新:使用material-ui 0.15.4,传递给onRowSelection处理程序的参数已更改。请参阅@Jonathn的答案,了解正确用法。

onRowSelection<Table>而非<TableRow>的属性。此外,它在调用(e)时不会使用事件调用处理程序,而是使用键调用它。然后,您可以使用它来查找行。像这样:

_onRowSelection(key) {
  console.log(key, this.state.data[key])
},

getInitialState() {
  return {
    data : [{id:0,name:"joe"},{id:1,name:"john"},{id:2,name:"Brad"},{id:3,name:"Jack"},{id:4,name:"Andrew"}],
    fixedHeader: true,
    fixedFooter: true,
    stripedRows: false,
    showRowHover: true,
    selectable: true,
    multiSelectable: false,
    enableSelectAll: false,
    deselectOnClickaway: true,
    height: '300px',
  };
},

render() {
  return (
    <div>
      <div className="col-sm-6">
        <h1>MagicTableReact</h1>
        <Table
          height={this.state.height}
          fixedHeader={this.state.fixedHeader}
          fixedFooter={this.state.fixedFooter}
          selectable={this.state.selectable}
          multiSelectable={this.state.multiSelectable}
          onRowSelection={this._onRowSelection}
        >
          <TableHeader>
            <TableRow>
              <TableHeaderColumn>ID</TableHeaderColumn>
              <TableHeaderColumn>Name</TableHeaderColumn>
            </TableRow>
          </TableHeader>
          <TableBody
          >
            {this.state.data.map((user, i) =>
              <TableRow key={i} value={user}>
                <TableRowColumn>{user.id}</TableRowColumn>
                <TableRowColumn>{user.name}</TableRowColumn>
              </TableRow>
            )}
          </TableBody>
        </Table>
      </div>
    </div>
  );
}

答案 1 :(得分:6)

  

使用[Material-UI 0.15.4]

onRowSelection仅返回noneall或包含所选行的行号的数组。

使用onCellClick同样在<Table>级别,会返回rowNumbercolumnNumberevent。此事件包含target下的表格单元格,您可以从那里引用data-标记等。

示例:

function handleCellClick (rowNumber, columnNumber, evt) {
  console.log("activityId", evt.target.dataset.myRowIdentifier);
}

function createTableRow (content) {
  let activityId = content.shift();
  return (
    <TableRow key={activityId}>
      {content.map((columnContent, i) => {
        return (
          <TableRowColumn key={i} data-my-row-identifier={activityId} >{columnContent}</TableRowColumn>
        );
      })}
    </TableRow>
  );
}

return (
  <div>
    <Table onCellClick={handleCellClick}>
      <TableHeader displaySelectAll={false} adjustForCheckbox={false}>
      {createHeaderRow(tableHeader)}
      </TableHeader>
      <TableBody displayRowCheckbox={false}>
      {filteredTable.map(createTableRow)}
      </TableBody>
    </Table>
  </div>
);

我在StackOverflow上的第一个答案......希望它有所帮助: - )

答案 2 :(得分:0)

<Table onCellClick={(row, col, event) => console.log(event.target.innerHTML)}>

答案 3 :(得分:0)

您可以使用初始数据数组并根据行号引用索引,以访问所选行以及与之关联的对象。这是一个基本示例,显然取决于您要对数据执行的操作,您可能需要添加更多逻辑。

_onRowSelection(rows) {
    for (let i = 0; i < rows.length; i++) {
        console.log(this.state.data[rows[i]])
    }
},

getInitialState() {
  return {
    data : [{id:0,name:"joe"},{id:1,name:"john"},{id:2,name:"Brad"},{id:3,name:"Jack"},{id:4,name:"Andrew"}]
  };
},

render() {
  return (
    <div>
      <div className="col-sm-6">
        <h1>MagicTableReact</h1>
        <Table onRowSelection={(rows) => this._onRowSelection(rows)}>
          <TableHeader>
            <TableRow>
              <TableHeaderColumn>ID</TableHeaderColumn>
              <TableHeaderColumn>Name</TableHeaderColumn>
            </TableRow>
          </TableHeader>
          <TableBody
          >
            {this.state.data.map((user, i) =>
              <TableRow key={i} value={user}>
                <TableRowColumn>{user.id}</TableRowColumn>
                <TableRowColumn>{user.name}</TableRowColumn>
              </TableRow>
            )}
          </TableBody>
        </Table>
      </div>
    </div>
  );
}