使用 svelte/store 更新方法更新对象时是否应该使用扩展运算符?

Ste*_*ell 6 svelte svelte-store

我正在创建一个使用对象来存储数据的商店。

我可以使用扩展运算符更新商店,但我也可以在不使用扩展运算符的情况下更新它。

Svelte 是否像 React 一样,我应该在更新对象的状态之前使用扩展运算符创建一个新对象,这样我就不会改变原始对象?

withSpreadOperator()或者withoutSpreadOperator()……这就是问题所在。

//stores.js

import { writable } from "svelte/store";

export const counts = writable({ n: 0 });
Run Code Online (Sandbox Code Playgroud)
//App.js

<script>
  import { count } from "./stores.js";

  function withSpreadOperator() {
    count.update(o => {
      let x = { ...o };
      x.n++;
      return x;
    });
  }

  function withoutSpreadOperator() {
    count.update(o => {
      o.n++;
      return o;
    });
  }
</script>

<h1>The count is {$count.n}</h1>
<button on:click="{withSpreadOperator}">+</button>
<button on:click="{withoutSpreadOperator}">+</button>
Run Code Online (Sandbox Code Playgroud)

Ric*_*ris 11

两者都可以,Svelte 并不介意。这实际上取决于您喜欢哪种风格。