英文:
React keeps re-rendering my components that i made by mapping over an object.entries(useState variable)
问题
我已经翻译好了您提供的内容:
我已经在React.js中编写了代码,它可以正常工作(渲染了一个简单的表格),但是表格元素每秒都在重新渲染,当我尝试突出显示某些内容时,它立即取消突出显示。
这是一个从Lichess API获取数据的React表格。
它可以渲染一个表格,但是td和tr元素不停地刷新。
我尝试了以下代码:
import './Recent.css';
import { React, useState, useEffect, useMemo } from 'react';
import { v4 as uuidv4 } from 'uuid';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { faSort, faSortUp, faSortDown } from '@fortawesome/free-solid-svg-icons';
import * as fetch from 'node-fetch';
function Recent() {
const [ratings, setRatings] = useState({});
const [headers, setHeaders] = useState([""]);
const [loaded, setLoaded] = useState(false);
const [vState, setVState] = useState('default');
const [dState, setDState] = useState('default');
const [rState, setRState] = useState('default');
const fetchRatings = () => {
fetch('lichesslinkthatyoudontgettosee')
.then(response => {
return response.json()
})
.then(data => {
setRatings(data);
setHeaders(["Variant", "Date", "Rating"]);
setLoaded(true);
});
}
useEffect(() => {
fetchRatings()
}, []);
function vCycle(vState) {
if (vState === 'default') {
setVState('dsc');
setDState('default');
setRState('default');
} else if (vState === 'dsc') {
setVState('asc');
} else {
setVState('default');
}
}
function dCycle(dState) {
if (dState === 'default') {
setDState('dsc');
setVState('default');
setRState('default');
} else if (dState === 'dsc') {
setDState('asc');
} else {
setDState('default');
}
}
function rCycle(rState) {
if (rState === 'default') {
setRState('dsc');
setVState('default');
setDState('default');
} else if (rState === 'dsc') {
setRState('asc');
} else {
setRState('default');
}
}
return (
<div className="container" style={{display: loaded ? 'flex' : 'none'}}>
Most Recent
| {item.name} | {item.points.at(-1)[1] + 1 + "/" + item.points.at(-1)[2] + "/" + item.points.at(-1)[0].toString().slice(2, 4) } | {item.points.at(-1)[3]} | 
);
}
// const displayInfo = () => (
// )
export default Recent;
表格不断地重新渲染,您该如何修复这个问题:
```javascript
import './App.css';
import Recent from './components/Recent';
function App() {
  return (
    <Recent />
  )
}
export default App;
英文:
i have written code in react js and it works (it renders a simple table) but the table elments keep rerendering every second and when i try to highlight something it unhighlights immediately
this is a react table that basically pulls from lichess api
it renders a table but the the td and trs keep refreshing constantly
i tried this
import './Recent.css';
import { React, useState, useEffect, useMemo } from 'react';
import { v4 as uuidv4 } from 'uuid';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
import { faSort, faSortUp, faSortDown } from '@fortawesome/free-solid-svg-icons'
import * as fetch from 'node-fetch';
function Recent() {
  const [ratings, setRatings] = useState({});
  const [headers, setHeaders] = useState([""]);
  const [loaded, setLoaded] = useState(false);
  const [vState, setVState] = useState('default');
  const [dState, setDState] = useState('default');
  const [rState, setRState] = useState('default');
  const fetchRatings = () => {
    fetch('lichesslinkthatyoudontgettosee')
      .then (response => {
        return response.json()
      })
      .then (data => {
        setRatings(data);
        setHeaders(["Variant", "Date", "Rating"]);
        setLoaded(true);
      });
  }
  useEffect(() => {
    fetchRatings()
  }, []);
  function vCycle(vState) {
    if (vState === 'default') {
        setVState('dsc');
        setDState('default');
        setRState('default');
    } else if (vState === 'dsc') {
        setVState('asc');
    } else {
        setVState('default');
    }
  }
  function dCycle(dState) {
    if (dState === 'default') {
        setDState('dsc');
        setVState('default');
        setRState('default');
    } else if (dState === 'dsc') {
        setDState('asc');
    } else {
        setDState('default');
    }
  }
  function rCycle(rState) {
    if (rState === 'default') {
        setRState('dsc');
        setVState('default');
        setDState('default');
    } else if (rState === 'dsc') {
        setRState('asc');
    } else {
        setRState('default');
    }
  }
  return (
    <div className="container" style={{display: loaded ? 'flex' : 'none'}}>
      <h2>Most Recent</h2>
      <table>
        <thead>
          <tr>
            <th onClick={() => vCycle(vState)}>{headers[0]} <span><FontAwesomeIcon fixedWidth transform="shrink-3" icon={vState === 'default' ? faSort : vState === 'asc' ? faSortUp : faSortDown} /></span></th>
            <th onClick={() => dCycle(dState)}>{headers[1]} <span><FontAwesomeIcon fixedWidth transform="shrink-3" icon={dState === 'default' ? faSort : dState === 'asc' ? faSortUp : faSortDown} /></span></th>
            <th onClick={() => rCycle(rState)}>{headers[2]} <span><FontAwesomeIcon fixedWidth transform="shrink-3" icon={rState === 'default' ? faSort : rState === 'asc' ? faSortUp : faSortDown} /></span></th>
          </tr>
        </thead>
        <tbody>
           {Object.values(ratings).filter(o => o.points.length).map((item) => {
                return (
                  <tr key={uuidv4()}>
                    <td className="variant">{item.name}</td>
                    <td className='date'>{item.points.at(-1)[1] + 1 + "/" + item.points.at(-1)[2] + "/" + item.points.at(-1)[0].toString().slice(2, 4) }</td>
                    <td className='rating'>{item.points.at(-1)[3]}</td>
                  </tr>
                )
           }) ?? null}
        </tbody>
      </table>
    </div>
  );
}
// const displayInfo = () => (
  
// )
export default Recent;
it keeps refreshing all the trs and tds
how can i fix this
import './App.css';
import Recent from './components/Recent';
function App() {
  return (
    <Recent />
  )
}
export default App;
答案1
得分: -1
将 "delete uuidv4() as key" 更改为 "item.name"。
英文:
delete uuidv4() as key and change to item.name
答案2
得分: -1
代码部分不需要翻译,以下是翻译好的部分:
"the code is well and nothing here that would cause re-renders try tracking your code using console.log to see if there is really re-renders and the parent component and check your css file"
"else you can wrap all the tr elements inside a React.memo"
"recent.jsx"
"return (
<table>
<TableRows someData={trProps} />
</table>
)"
"Table rows component:"
"const TableRows = React.memo( ({someData}) => /* Triggers update only if 'someData' changes */
<> { someData.map( data => <tr>{data}</tr> ) } </>
)"
英文:
the code is well and nothing here that would cause re-renders try tracking your code using console.log to see if there is really re-renders and the parent component and check you css file
       {Object.values(ratings).filter(o => o.points.length).map((item) => {
           
            console.log('item.name');
            return (
              <tr key={uuidv4()}>
                <td className="variant">{item.name}</td>
                <td className='date'>{item.points.at(-1)[1] + 1 + "/" + item.points.at(-1)[2] + "/" + item.points.at(-1)[0].toString().slice(2, 4) }</td>
                <td className='rating'>{item.points.at(-1)[3]}</td>
              </tr>
            )
       }) ?? null}
else you can wrap all the tr elements inside a React.memo
recent.jsx
return (
  <table> 
    <TableRows someData={trProps} />
  </table>
)
Table rows component:
const TableRows = React.memo( ({someData}) => /* Triggers update only if 'someData' changes */
      <> { someData.map( data => <tr>{data}</tr> ) } </>
    )


评论