如何比较 Svelte 3 中的 Prop 变化

2023-12-23

Svelte 3 中是否有一种机制可以在渲染之前比较组件内的 prop 更改?类似于 反应从Props获取DerivedState https://reactjs.org/docs/react-component.html#static-getderivedstatefromprops.

<script>
 export let color;

  // Does anything like this exist in Svelte?

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

如果你只想在以下情况下执行一段代码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>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何比较 Svelte 3 中的 Prop 变化 的相关文章

随机推荐