feat: add onAnimationFrame lifecycle function

#14594

Pull request

Open
R
Rich-Harris
Dec 6, 2024, 8:40 PM

Just an idle thought I had while washing the dishes: should we have an onFrame function? It would mean for example that this demo could be written like this:

$effect(() => {
  const context = canvas.getContext('2d');

  onFrame(() => {
    paint(context, Date.now());
  });
});

Alternatively we might want to have some sort of reactive time primitive (other than SvelteDate) so that it could be used in deriveds too. Either way not wedded to it, just an idle thought that I thought was worth a PR

Before submitting the PR, please make sure you do the following

  • It's really useful if your PR references an issue where it is discussed ahead of time. In many cases, features are absent for a reason. For large changes, please create an RFC: https://github.com/sveltejs/rfcs
  • Prefix your PR title with feat:, fix:, chore:, or docs:.
  • This message body should clearly illustrate what problems it solves.
  • Ideally, include a test that fails without this PR but passes with it.
  • If this PR changes code within packages/svelte/src, add a changeset (npx changeset).

Tests and linting

  • Run the tests with pnpm test and lint the project with pnpm lint

Info

Assignees None
Reviewers None
Labels needs discussion
Milestone None