Can find the answer in the source code: the SRC/corn/instance/state. The js (initData method)
-
First we find the answer in the bear source code, post a source map
The source code determines whether data is a function. If it is a function, it will use getData() to execute the following, and the result of the execution as the final value, otherwise, it will use the user set data directly
Take a look at the following code snippet to make any guesses about data as a function:
Vue.component('comp'{
data:{count:1}
})
Copy the code
If data is an object, the else code in the source code will be used directly to use the data passed in by the user. If there are multiple components, data data will be shared, which will form data pollution.
If you execute the code in the previous example, it will throw a warning saying that data must be a function;
Conclusion: In order for the states of each component to not interfere with each other and not pollute data, data must be a factory function.
The second question is, why does data have to be a function in a Vue component when data is not displayed in the root instance of vue? 1. Only one root instance can be created using the new method, which is a singleton. Unlike many vUE component instances, data pollution and mutual interference in VUE component instances will not occur.
Corn /util/option.js
First check whether it is a VUE component, then the third parameter VM instance will not be passed when mergeDataOrFn method is executed, so function verification will be performed. However, if the root instance is passed when mergeDataOrFn method is executed, the third parameter vm instance will be passed when mergeDataOrFn method is executed. So it avoids function verification; So in summary, there are two reasons why data of a data root instance is unbounded.
The meeting ~ ~ ~ ~ ~