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

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