- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在创建一个带有可编辑详细信息列表的 React 应用程序。我的问题是我无法快速更新列表。特别是 Internet Explorer 正在努力分配。
使用我的应用程序作为示例会太多,因此我在codesandbox中创建了一个简化的概念: https://codesandbox.io/s/bold-sanderson-of08y
对于这个例子,我只是渲染了很多 <input/>
并让父容器处理状态。
function App() {
console.log('Render App')
const [items, setItems] = useState(createItems())
const handleChange = (value, index) => {
const itemsCopy = [...items]
itemsCopy[index] = value
setItems(itemsCopy)
}
const handleSave = () => {
//Send data to back-end etc...
//webAPI.saveData(items)
}
return (
<div>
<button onClick={handleSave}>Save</button>
<hr />
{items.map((item, index) => {
return (
<input
key={index}
value={item}
onChange={e => handleChange(e.target.value, index)}
/>
)
})}
</div>
)
}
这个演示有点极端,因为每次按键都会触发状态更新。但对于这个例子来说它很好。
我想知道的是如何处理这种情况,而不需要每次都重新渲染“App”组件。我正在考虑将状态移至输入组件本身,但如果这样做,我将无法评估 handleSave
中的所有数据。功能。或者至少我不知道如何实现这一点。
最佳答案
关于javascript - React 更新列表项状态尽可能提高性能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60266628/
我知道在 KDB 中,如果您有一个列表,例如... l:`apples`oranges`pears` 您可以像下面这样进行 N 次随机选择: 9?l 但是如何尽可能均匀地选择列表中的每个项目? 最佳答
我真的厌倦了它。我有一个高级 Web 应用程序依赖于大量 Javascript 库(jQuery、jQueryUI、OpenLayers、highcharts、EJSChart 等等)。不用说,Int
我是一名优秀的程序员,十分优秀!