316

Vue.js documentation describes the created and mounted events as follows:

created

Called synchronously after the instance is created. At this stage, the instance has finished processing the options which means the following have been set up: data observation, computed properties, methods, watch/event callbacks. However, the mounting phase has not been started, and the $el property will not be available yet.

mounted

Called after the instance has just been mounted where el is replaced by the newly created vm.$el. If the root instance is mounted to an in-document element, vm.$el will also be in-document when mounted is called.

This hook is not called during server-side rendering.

I understand the theory, but I have 2 questions regarding practice:

  1. Is there any case where created would be used over mounted?
  2. What can I use the created event for, in real-life (real-code) situation?
5
  • 42
    created is called earlier, so it makes sense to trigger data fetching from API backend for example. Commented Aug 22, 2017 at 9:22
  • 7
    Can confirm, the examples in Fullstack Vue book all use created() to dispatch actions for api calls. Commented Sep 26, 2018 at 6:11
  • @EgorStambakio What if i dont use created in my component and I use only mounted, is not almost the same in mounted to call the api?I mean that the created hook will be skipped since it wont be called. Commented Jan 13, 2021 at 10:47
  • @LastM4N you can do it in mounted, that's your choice. But because the hooks run synchronously, you want to do it in the right place. Since the API call has nothing to do with the DOM, it belongs in the created hook. Commented Jan 24, 2021 at 20:46
  • 1
    @wittgenstein ok we agree, although Vue official doc uses the mounted hook vuejs.org/v2/cookbook/using-axios-to-consume-apis.html Commented Jan 24, 2021 at 20:54

2 Answers 2

432

created() : since the processing of the options is finished you have access to reactive data properties and change them if you want. At this stage DOM has not been mounted or added yet. So you cannot do any DOM manipulation here

mounted(): called after the DOM has been mounted or rendered. Here you have access to the DOM elements and DOM manipulation can be performed for example get the innerHTML:

console.log(element.innerHTML)

So your questions:

  1. Is there any case where created would be used over mounted?

Created is generally used for fetching data from backend API and setting it to data properties. But in SSR mounted() hook is not present you need to perform tasks like fetching data in created hook only

  1. What can I use the created event for, in real-life (real-code) situation?

For fetching any initial required data to be rendered(like JSON) from external API and assigning it to any reactive data properties

data:{
    myJson : null,
    errors: null
},
created(){
    //pseudo code
    database.get().then((res) => {
        this.myJson = res.data;
    }).catch((err) => {
        this.errors = err;
    });
}
Sign up to request clarification or add additional context in comments.

14 Comments

When making api call in created does it wait for all of the async operations to complete before moving on to the next life cycle stage?
@Ominus no it does not wait, Run this fiddle- jsfiddle.net/1k26sqrx/] and check out the console logs
I've noticed that when mounted() is used instead of created(). Vue tests if the reactive variable set, really exists as reactie variable. If not, an error is thrown. This is not the case in created() "Property or method "foo" is not defined on the instance but referenced during render. Make sure that this property is reactive."
@tobiasBora as long as you do not need to interact with DOM, created should do
@tobiasBora by several objects if you mean multiple due instances, yes every vuue instance will call it's respective created hook. But created is called only once when a due object is instantiated.
|
-4

For the created() hook, the data after manipulation in the browser it not shown in the DOM before mounted. In simple words the data takes time to manipulate the DOm seen the browser .

The mounted() hook is called after the DOM has been mounted or rendered which enables you to have access to the DOM elements and you can perform DOM manipulation.The best use for the mounted hook is if you need to access the DOM immediately before or after the initial render.

3 Comments

You are rehashing an existing answer.
I did'n rehash any existing answer
Yes... you did.

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.