Как сравнить изменения свойств в Svelte 3

Есть ли в 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>

person JeffD23    schedule 11.11.2019    source источник


Ответы (2)


Если вы хотите выполнять фрагмент кода только при изменении 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>
person Tan Li Hau    schedule 12.11.2019
comment
Почему Svelte пришлось все делать так просто? Спасибо! - person JeffD23; 12.11.2019
comment
просто интересно, может ли установка prevColor вызвать другой реактивный оператор, где используется prevColor. - person thecodejack; 06.01.2020
comment
comment
вроде как .. но вот меня и беспокоило именно это .. svelte.dev/repl/d4156f465dbe42a ? version = 3.16.7 .. с ReactJS вы не можете сделать это простым способом, но я вижу, что Svelte справляется с этим правильно ... Замечательно - person thecodejack; 16.01.2020

На самом деле я написал пакет, который использует Svelte Stores, чтобы дать вам простой интерфейс для ссылки на столько предыдущих значений, сколько вам нужно.

Svelte Previous.

<script>
  export let color;
  const [currentColor, previousColor] = usePrevious(color);
  $: $currentColor = color;
</script>

{$previousColor} to {$currentColor}
person Bryan Lee    schedule 05.02.2021