React-window 失去焦点
我将 react-window
与 react-table
一起使用,当我在单元格中输入内容,然后单击另一个单元格时,我必须再次单击才能获取聚焦下一个单元格,以便我可以打字。我认为这与 key
无关 - 这是反应失去焦点的常见情况。几乎可以肯定它与react-window
有关。删除它后,问题就消失了。
当我用鼠标滚动时,焦点也会丢失。因此,如果我将注意力集中在一个单元格上,然后用鼠标滚轮滚动,它就会变得模糊。
代码沙箱:
import React from 'react'
import { useTable } from 'react-table'
import { FixedSizeList } from 'react-window'
const EditableCell = ({
value: initialValue,
row: { index },
column: { id },
updateMyData,
}) => {
const [value, setValue] = React.useState(initialValue)
const onChange = e => setValue(e.target.value)
const onBlur = () => updateMyData(index, id, value)
React.useEffect(() => {setValue(initialValue)}, [initialValue])
return <input value={value} onChange={onChange} onBlur={onBlur} />
}
const defaultColumn = { Cell: EditableCell, width: 200,}
function Table({ columns, data, updateMyData }) {
const table = useTable({columns, data, defaultColumn, updateMyData})
const RenderRow = React.useCallback( ({ index, style }) => {
const row = table.rows[index]
table.prepareRow(row)
return (
<tr {...row.getRowProps({ style })} className="tr">
{row.cells.map(cell => (
<td {...cell.getCellProps()} className="td">
{cell.render('Cell')}
</td> ))}
</tr> )
}, [table.prepareRow, table.rows])
return (
<table {...table.getTableProps()}>
<tbody {...table.getTableBodyProps()}>
<FixedSizeList
height={400}
itemCount={table.rows.length}
itemSize={35}
width={table.totalColumnsWidth}
>
{RenderRow}
</FixedSizeList>
</tbody>
</table>
)
}
function App() {
const columns = React.useMemo(
() => [
{Header: 'Name',accessor: 'name',},
],
[]
)
const [data, setData] = React.useState(() => {return Array(1000).fill({name:'Jack'})})
const updateMyData = (rowIndex, columnId, value) => {
const temp = [...data]
temp[rowIndex]={...temp[rowIndex],[columnId]:value}
setData(temp)
}
return ( <Table columns={columns} data={data} updateMyData={updateMyData} /> )
}
export default App
I'm using react-window
together with react-table
and when I type something in a cell, an then click on another cell, I have to click again to get the next cell focused so I can type. I don't think it has to do with key
- the usual case of react loosing focus. Almost sure it has to do with react-window
. When removing it, the issue is gone.
Focus is also being lost when I scroll with the mouse. So if I'm focused in a cell, and then scroll with the mouse wheel, it blures.
import React from 'react'
import { useTable } from 'react-table'
import { FixedSizeList } from 'react-window'
const EditableCell = ({
value: initialValue,
row: { index },
column: { id },
updateMyData,
}) => {
const [value, setValue] = React.useState(initialValue)
const onChange = e => setValue(e.target.value)
const onBlur = () => updateMyData(index, id, value)
React.useEffect(() => {setValue(initialValue)}, [initialValue])
return <input value={value} onChange={onChange} onBlur={onBlur} />
}
const defaultColumn = { Cell: EditableCell, width: 200,}
function Table({ columns, data, updateMyData }) {
const table = useTable({columns, data, defaultColumn, updateMyData})
const RenderRow = React.useCallback( ({ index, style }) => {
const row = table.rows[index]
table.prepareRow(row)
return (
<tr {...row.getRowProps({ style })} className="tr">
{row.cells.map(cell => (
<td {...cell.getCellProps()} className="td">
{cell.render('Cell')}
</td> ))}
</tr> )
}, [table.prepareRow, table.rows])
return (
<table {...table.getTableProps()}>
<tbody {...table.getTableBodyProps()}>
<FixedSizeList
height={400}
itemCount={table.rows.length}
itemSize={35}
width={table.totalColumnsWidth}
>
{RenderRow}
</FixedSizeList>
</tbody>
</table>
)
}
function App() {
const columns = React.useMemo(
() => [
{Header: 'Name',accessor: 'name',},
],
[]
)
const [data, setData] = React.useState(() => {return Array(1000).fill({name:'Jack'})})
const updateMyData = (rowIndex, columnId, value) => {
const temp = [...data]
temp[rowIndex]={...temp[rowIndex],[columnId]:value}
setData(temp)
}
return ( <Table columns={columns} data={data} updateMyData={updateMyData} /> )
}
export default App
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
通过在 Table 组件外部声明 RenderItem 组件来修复。因此组件没有重新声明,只是更新了 props。 (建议永远不要在父组件中声明子组件)
代码沙箱
Fixed by declaring the RenderItem component outside of the Table Component. So the component is not re-declared, but just the props are updating. (As recomended never to have child components declared inside Parent component)
Code Sandbox