[Vuejs]-What is flush:post in vue.js watchers?

0👍

The flush: 'post' option means, that the handler is fired after vue has updated the component and has updated the Browser DOM.

Without this, the handler will be triggered directly when a value changes which does not necessarily means, that vue has already updated the component in the browser. If you want to perform a side effect that requires access to the DOM, you need to make sure, that vue has already done the update of the DOM

I would recommend to check out the lifecycle documentation in the vue documentation. This might give you an idea of how the lifecycle work in reactive frameworks.

Example

Imagine, you change a className based on a state variable. After you changed the class you want to know the height of your element. (The example is in Vue 3 composition API, but it works the same within the Vue 2 options api.)

export default defineComponent({
  setup() {
    const myElement = ref(null);
    const someState = ref(false);

    const rootClasses = computed(() => ({
      'my-class': someState.value,
    }))

    const handleClick = () => {
      someState.value = false;
    }

    watch(
      someState,
      (newSomeState) => {
        if (!myElement.value || !newSomeState) return;
        const height = myElement.offsetHeight;
        // do something with the height here.
      },
      { flush: 'post' }
    );
  }
})

Leave a comment