1. ホーム
  2. reactjs

MaterialUI カスタムホバースタイル

2023-08-13 03:48:54

質問

私はReactの初心者ですが、マテリアルUIでクラスをオーバーライドする方法について少し混乱しています。私は例を見て、それを模倣しようとしましたが、それは私がやりたいことをやっていないようです。

基本的に、テーブル行のホバー時に、現在とは異なる背景色を設定するようにしたいのです。

以下は私のアプローチです。

const styles = theme => ({
  root: {
    width: "100%",
    marginTop: theme.spacing.unit * 3
  },
  table: {
    minWidth: 1020
  },
  tableWrapper: {
    overflowX: "auto"
  },
  hover: {
    "&:hover": {
      backgroundColor: 'rgb(7, 177, 77, 0.42)'
    }
  }
});

return <TableRow hover classes={{hover: classes.hover}} role="checkbox" aria-checked={isSelected} tabIndex={-1} key={n.row_id} selected={isSelected}>
     {this.insertRow(n, isSelected, counter, checkbox)}

;

export default withStyles(styles)(EnhancedTable);

ご協力ありがとうございました。

どのように解決するのですか?

TableRow のキーを className として定義し、そのクラス名をオブジェクトとしてホバースタイルを配置する必要があります。

const styles = theme => ({
  ...
  tr: {
    background: "#f1f1f1",
    '&:hover': {
       background: "#f00",
    },
  },
  ...
});

return <TableRow className={props.classes.tr} ...>

別の例では、次のようなものです。

const styles = {
  tr: {
    background: "#f1f1f1",
    '&:hover': {
      background: "#f00",
    }
  }
};

function Table(props) {
  return (
    <Table>
      <TableRow className={props.classes.tr}>
        {"table row"}
      </TableRow>
    </Table>
  );
}

export default withStyles(styles)(Table);