Skip to content

Instantly share code, notes, and snippets.

@Rich-Harris
Last active November 1, 2018 21:22
Show Gist options
  • Save Rich-Harris/5baca5f6c05b7adfd9f59fe3ebacb584 to your computer and use it in GitHub Desktop.
Save Rich-Harris/5baca5f6c05b7adfd9f59fe3ebacb584 to your computer and use it in GitHub Desktop.
πŸ€”πŸ€”πŸ€”
<div on:click="set({ count: count + 1 })">
{count} {double}
</div>
<script>
export default {
data() {
return { count: 0 };
},
computed: {
double: ({ count }) => count * 2
}
};
</script>
<script>
let count = 1;
const double = () => count * 2;
</script>
<div on:click="count += 1">
{count} {double()}
</div>
@Rich-Harris
Copy link
Author

Other things I'm thinking about:

  • namespace: 'svg' β€” perhaps this becomes <svelte:meta namespace="svg">?
  • tag β€” perhaps this becomes <svelte:meta tag="my-element">? (We no longer need props, since this is defined by export let xxx)
  • Firing events. The best thought I've had on this so far is
<script>
  import { createEventDispatcher } from 'svelte';

  const dispatch = createEventDispatcher();
</script>

<div on:click="dispatch({ type: 'foo', x: 1 })">...</div>
  • Speaking of events: would be cool to align these with CustomEvent and get things like bubbling.
  • Also speaking of events: does it now make sense to go with <button on:click={e => doThing(e)}>?
  • Component bindings
  • Component refs... do these still make sense?
  • Interacting with a component from JS. What is the external API?
  • The mechanism for responding to changes: At the moment, onstate fires for updated props or internal state (because there's no distinction between the two). This results in cyclicality (when you call this.set(...) inside onstate) which leads to confusion and bugginess. I'd propose that we make that completely impossible by only calling onstate (or more likely onchange) when props have changed. I can't think of anything that would become impossible as a result, except for things that we want to be impossible. Also, we'd get rid of the arguments to onstate β€” no longer necessary.

@Rich-Harris
Copy link
Author

Preload! We need to figure out how to support preload β€” doesn't need to be the exact same mechanism, but something like it. (We could abandon it in favour of doubling down on Suspense, but it wouldn't quite cover the same area.

@Rich-Harris
Copy link
Author

In fact SSR more generally is a big unknown. In this new world, the initial setup code (which is currently what we'd call oncreate) always runs, on both client and server. onchange and onrender (or whatever) would never run. ondestroy could either be a noop (in which case any mount code would have to be wrapped in if (process.browser) or something), or it could be called immediately following render.

It's possible that we'd lose the API distinction between client and server. We could also consider introducing async SSR rendering. Lot of possibilities, lot of stuff to figure out.

@Rich-Harris
Copy link
Author

Oh, and all this needs to work with standalone components as well as normal ones

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment