169 похожих чатов

Привет всем. У меня не получается понять, как работает each

с ключом. Как сделать, чтобы formatDate не вызывалось 500 раз (вообще не вызывалось), когда нажимаешь кнопку SPLICE? Код для REPL:


<script>
let messages = []
const tmp = []
for (let i = 0; i < 500; i++)
tmp.push({ timestamp: 60000 * i })
messages = tmp


const formatDate = timestamp => {
console.log('formatDate')
return new Date(timestamp).toLocaleString('ru')
}

const splice = () => {
messages.splice(1, 1)
messages = messages
}
</script>

<div on:click={splice}>SPLICE!</div>
{#if messages.length}
{#each messages as msg (msg.timestamp)}
{formatDate(msg.timestamp)}
<br>
{/each}
{/if}

3 ответов

5 просмотров

https://svelte.dev/repl/7e35f641bdea48bcb21a599dfb7b087a?version=3.22.2

через options immutable можно. без доп компонента не придумал https://svelte.dev/repl/598ab299720e4bb2b8955f92305c33e3?version=3.22.2

а я бы не рекомендовал исползовать splice потому что он мутирует текущий массив, а это может породить ошибки. Я бы делал как тио так: https://svelte.dev/repl/4efb6df98f9c484a9aac494fd1202667?version=3.22.2

Похожие вопросы

Обсуждают сегодня

А чем вам питонисты не угодили?😂
.
79
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Anyone knows how to build this widget in Flutter? I have all the assets for round stations and the road, but how can I make the my widget animate between these stations? And h...
Mohammad Zamani
9
короче я не выдержал постоянно определять структуры, чтобы возвращать массивы разных типов. Как обычно еще это делают?
Павλо 🇺🇦
7
Подскажите как мне лучше держать websocket сединение и переодически передавать в него данные? Сначала я сделал так: for _ in 1...1000 { try? await ws.send("test") try...
Mihail Verenich
2
А цены чем оправданы?
Lencore
7
Добрый вѣчер! Помню не раз было, но 1001 раз не лишний. Почему данные (элементы) из TList<TMyClass> куда то деваются? Точнее ранее прикопаный на них указатель больше не указыв...
Евгений
3
Ты просто гитлеровскую эстетику плохо понимаешь. Он же всё под Цезаря делал. А это как бы запрещённый приём в политике. Пиджаки они зачем все носят? Чтобы показать что они тип...
Ivan Kropotkin
4
Карта сайта