Как сравнить изменения в Prop в Svelte 3 - PullRequest
3 голосов
/ 12 ноября 2019

Есть ли в Svelte 3 механизм для сравнения изменений реквизита внутри компонента перед рендерингом? Аналогично React getDerivedStateFromProps .

<script>
 export let color;

  // Does anything like this exist in Svelte?

  beforeUpdate((changes) => {
     const same = changes.prev.color === changes.next.color
  })
</script>

1 Ответ

8 голосов
/ 12 ноября 2019

Если вы хотите выполнить фрагмент кода только при изменении color, вы можете использовать реактивное объявление:

<script>
  export let color;

  $: {
     console.log('color changed', color);
     // will only get called when the `color` changed.
  }
</script>

Но если вы хотите выполнить этот фрагмент кода как с текущим значениеми предыдущее значение, вы можете сделать следующее:

<script>
  export let color;
  let prevColor;

  $: {
     console.log('currentColor:', color, 'prevColor:', prevColor);
     prevColor = color;
  }
</script>
...