首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么Vue DOM的变化这么慢?

为什么Vue DOM的变化这么慢?
EN

Stack Overflow用户
提问于 2022-04-15 07:30:33
回答 1查看 661关注 0票数 6

我有一个2000输入复选框的列表。当同时选择它们时,明显的延迟(和浏览器冻结)大约是2秒。这似乎是Vue和React的情况,但对于Svelte、jQuery或香草则不然。

有了5k+复选框,它就变成了一个非常恼人的3-5秒的阻止程序.

为什么重渲染要花这么长时间?

如何用Vue.js克服更新延迟?

(分页或延迟加载的解决方案并不能真正解决问题,而是在回避问题。)

下面是Vue中的代码,后面是Svelte中的相同示例。

代码语言:javascript
复制
<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>

Vue证监会链接

苗条:

代码语言:javascript
复制
<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>

Svelte REPL链接

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-04-15 09:39:33

1. 缓慢变化的原因

代码语言:javascript
复制
<label v-for="n in items">
    <input v-model="selected" type="checkbox" :value="n">
    {{ n }}
</label>

您使用所选的v模型,但选择了is数组,并且在每个2000输入的v模型中放置了整个2000值数组,这就是浏览器等待的原因。

2.求解

您可以在输入中使用

代码语言:javascript
复制
<label v-for="n in items">
    <input v-model="selected[n]" type="checkbox" :value="n">
    {{ n }}
</label>

还可以在脚本中更改selectAll函数

代码语言:javascript
复制
function selectAll() {
    selected = items.map(i => true);
}
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71881253

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档