Skip to content

Instantly share code, notes, and snippets.

Focusing on Vue 3.

Evan You yyx990803

Focusing on Vue 3.
Block or report user

Report or block yyx990803

Hide content and notifications from this user.

Learn more about blocking users

Contact Support about this user’s behavior.

Learn more about reporting abuse

Report abuse
View GitHub Profile
yyx990803 / commits.vue
Last active Nov 11, 2019
Vue examples comparisons in 2.x and function-based APIs
View commits.vue
<div id="demo">
<h1>Latest Vue.js Commits</h1>
<template v-for="branch in branches">
<input type="radio"
<label :for="branch">{{ branch }}</label>

2.6 Internal Change: Scoped Slot Function Return Value

This change only affects render function users. If you only use templates, you can ignore this change.

The Problem

In render functions, scoped slots are exposed on this.$scopedSlots as functions. Up until now, calling a scoped slot function can return a single VNode or an Array of VNodes based on what the parent component is passing in. For example, given this component:

const Child = {
View async-error.js
export default {
async mounted() {
// if an async error is thrown here, it now will get
// caught by errorCaptured and Vue.config.errorHandler
this.posts = await api.getPosts()
View esm.html
<script type="module">
import Vue from ''
new Vue({
// ...
View observable.js
const reactiveState = Vue.observable({
count: 0
View dynamic-directive-argument.html
<div v-bind:[attr]="value"></div>
<div :[attr]="value"></div>
<button v-on:[event]="handler"></button>
<button @[event]="handler"></button>
<template v-slot:[slotName]>
Dynamic slot name
View slot-example.html
<template v-slot:header>
<template v-slot:item="{ data }">
<h2>{{ data.title }}</h2>
<p>{{ data.text }}</p>

2.6 Internal Change: Reverting nextTick to Always Use Microtask

The Original Problem

When Vue detects data mutation, it asynchronously defer DOM updates to the next "tick" so that multiple mutations trigger only one update cycle. In versions before 2.5, Vue has been deferring updates using what is known as the "Microtask" (as explained in this blog post).

This works fine in most situations, but we discovered an edge case:

  1. Given two nested elements, "outer" and "inner";
  2. "inner" has a click event handler which triggers an update
View syntax.vue
<template #header>
<div>Header message</div>
<template #item="{ item }">
<div class="item">{{ item.text }}</div>
<template #footer>
yyx990803 / slot-alias.vue
Last active Jan 14, 2019
Comparison of `slot-props`/`()` vs `slot-scope`
View slot-alias.vue
Proposed new usage - `()` is a shorthand of `slot-props`.
<!-- default slot with just text -->
<foo ()="foo">
{{ foo }}
<!-- default slot with element -->
<foo ()="foo">
You can’t perform that action at this time.