我有一个2000输入复选框的列表。当同时选择它们时,明显的延迟(和浏览器冻结)大约是2秒。这似乎是Vue和React的情况,但对于Svelte、jQuery或香草则不然。
有了5k+复选框,它就变成了一个非常恼人的3-5秒的阻止程序.
为什么重渲染要花这么长时间?
如何用Vue.js克服更新延迟?
(分页或延迟加载的解决方案并不能真正解决问题,而是在回避问题。)
下面是Vue中的代码,后面是Svelte中的相同示例。
<script setup>
import { ref } from 'vue'
const items = ref(Array.from({length: 2000}, (v, k) => k));
let selected = ref([]);
function selectAll() {
selected.value = items.value.map(i => i);
}
</script>
<template>
<button @click="selectAll">
Select all
</button>
<button @click="selected = []">
Select none
</button>
<label v-for="n in items">
<input v-model="selected" type="checkbox" :value="n">
{{ n }}
</label>
</template>
<style>
label {
display: block;
}
</style>苗条:
<script>
let items = Array.from({length: 2000}, (v, k) => k);
let selected = [];
function selectAll() {
selected = items.map(i => i);
}
</script>
<button on:click={selectAll}>
Select all
</button>
<button on:click="{() => selected = []}">
Select none
</button>
{#each items as n, i}
<label>
<input type=checkbox bind:group={selected} value={n}>
{n}
</label>
{/each}
<style>
label {
display: block;
}
</style>发布于 2022-04-15 09:39:33
1. 缓慢变化的原因
<label v-for="n in items">
<input v-model="selected" type="checkbox" :value="n">
{{ n }}
</label>您使用所选的v模型,但选择了is数组,并且在每个2000输入的v模型中放置了整个2000值数组,这就是浏览器等待的原因。
2.求解
您可以在输入中使用
<label v-for="n in items">
<input v-model="selected[n]" type="checkbox" :value="n">
{{ n }}
</label>还可以在脚本中更改selectAll函数
function selectAll() {
selected = items.map(i => true);
}https://stackoverflow.com/questions/71881253
复制相似问题