preface
Vue3 has been around for a while, and as a front-end developer, it’s important to keep up with current events, learn about new technologies, and stay relevant. In addition, vuE3 is certainly improved in performance for VUE2, which indicates that vuE2 may be replaced by VUE3 in the subsequent technical innovation, of course, it is not a matter of time. So while it’s hot, learn as long as you don’t die.
Here’s a summary of some of the features I learned while studying Vue3, and write them down to understand them.
Reactive
Reactive. Reactive. Reactive. Reactive. Reactive. Reactive. Reactive. Reactive. Reactive. Reactive. Reactive. Reactive. Reactive. Reactive. Reactive. Reactive.
const user = reactive({name:'zhangsan', age:18})
Copy the code
And just because the user object has a response, it doesn’t mean that user.name and user.age have a response. So when we return from setup we need to return the entire object:
const user = reactive({ name: 'zhangsan', age: 18}) {return {user} {// If the user is not a member of the template, it is not a member of the template. Reactive {user} If you want to respond to every value in the user object, use toRefs // return {//... user // }Copy the code
This is how it is used in a template:
<p>reactive : {{ user.name }} - {{ user.age }}</p>
Copy the code
How to get and set the value of an object
SetTimeout (() => {// Note: Value User. age = 21 // Obtain the value // console.log(user.age)}, 1500).Copy the code
As for the principle: from vuE3 with proxy implementation, interested students can go to understand.
ref
Reactive = reactive = reactive = reactive = reactive = reactive = reactive = reactive = reactive = reactive = reactive = reactive = reactive
< the template > < div > < p > ref, {{age}} < / p > < / div > < / template >... const age = ref<number>(10) return { age }Copy the code
The following code comments also explain how to set and get the ref value (where.value is needed) :
SetTimeout (() => {// This change is equivalent to a change in the value of the reference type, which can be responded to by the original object // similar: // const a = {age:11} // const b = a // b.ge = 12 // console.log(a.ge) // 12 // Value age = 13}, // let age = 10 // setTimeout(() => {// age = 15 //}, 1500);Copy the code
So the use of both ref and reactive can include all types of reactive processing. For bidirectional binding this is a feature that VUE has long prided itself on.
toRef
The function is to make an attribute of a reference type responsive. For example:
const user = reactive({ name: 'lisi', age: Const ageToRef = toRef(user, 'age') const ageToRef = toRef(user, 'age') ageToRef }Copy the code
This is why, when I introduced reactive, I emphasized that reactive is only a response to the reference type itself, not to its properties. With the blessing of toRef, you can now implement a response to the value of an object’s property.
Setting and getting toRef values:
SetTimeout (() => {ageToref.value = 18 // console.log(agetoref.value)}, 1500)Copy the code
toRefs
Type and toRef, but toRefs is obviously a complex number, so what it does is make all attributes that refer to the type reactive:
setup() { const user = reactive({ name: 'jojo', age: 19}) // Make the whole object const responsive userToRefs = toRefs(user) // split each of the attributes of the object to make it also const responsive {name, SetTimeout (() => {age. Value = 21}, 1500) return {name, age}}Copy the code
You can use attributes directly in the template:
<template>
<div>
<p>toRefs: {{ name }} - {{ age }}</p>
</div>
</template>
Copy the code
Midway summary
-
Reactive, ref,reactive
A: Because reactive value types need to be refs, reactive reference types need to be reactive. Reactive value types need to be reactive. Reactive value types need to be reactive.
-
Why use toRef, toRefs:
Answer: Because toRef shows that the value type in the specified object needs to be responsive, whereas toRefs implicitly specifies that all of the object’s properties are responsive.
-
Using toRefs, you can deconstruct an object so that its return properties can be used in a template alone.
watch
“Watch” in VUe3 and “watch” in VUE2 are always the same in the sense of listening for changes in data. However, VUE3 distinguishes between reactive type of reference and ref type of value type. Watch in VUE3 seems to be more different from reactive type. Let’s look at usage first:
setup() { const wNumber = ref<number>(100) const user = reactive({ name: 'zhangsan', age: // watch listener (wNumber, (newVal, oldVal) => {console.log(newVal, oldVal); Reactive watch(() => user.age, (newVal, oldVal) => {console.log(newVal, oldVal); reactive watch(() => user.age, (newVal, oldVal) => {console.log(newVal, oldVal); oldVal) } ) return { wNumber, user } }Copy the code
As you can see from the above code, there are slightly different ways to write different responses.
watchEffect
Surprisingly, vue3 also refers to the Watch Effect API in addition to the Watch setup, which also means listen. So what’s the difference?
setup() { const wNumber = ref<number>(100) const user = reactive({ name: 'zhangsan', age: 18}) watchEffect(() => {// wNumber is automatically listened for here The console. The log (` - ${wNumber. Value} -- -- -- -- -- `)}) watchEffect (() = > {/ / here to automatic monitoring to the user. The name, the user. The age console.log(`----${user.name}--${user.age}---`) }) setTimeout(() => { wNumber.value = 200 }, 1500) setTimeout(() => { user.age = 20 }, 2000) return { wNumber, user } }Copy the code
As noted in the comment, the watchEffect does not need to be listened on. Instead, the setup is initialized once, and once this is done, the watchEffect knows which values in the callback function need to be listened on. So when we trigger the change we automatically listen for the change. I don’t know when this property will be used again, but I have to say that the vuE3 team is very thoughtful.
Other features
Proxy
Proxy response replaces the Object. DefineProperty in VUE2, which is solved when setting new values and deleting values, and optimizes the problem of one-time recursive listening in Object. DefineProperty. Proxy recurses according to the depth of the value. For example, if an object has 5 layers and obtains the value of a property at the third layer, Proxy will only recurse to the property at the third layer.
PatchFlag
Add tags to the dynamic nodes, dynamic node is similar to: {{MSG}}, compile the parsing process will add tags to the dynamic node. In this way, diff algorithm can directly compare marked dynamic nodes without comparing static nodes when comparing DOM trees.
hoistStatic
During compilation, promote static node variables to the parent scope and cache them. Secondly, multiple static nodes together over a certain number will be merged into A DOM string for direct parsing.
cacheHandler
Cache events. If there is an event cache, retrieve it. If there is no event cache, redefine it.
SSR optimization
Similar to hoistStatic, multiple static nodes are merged into DOM strings for optimization to facilitate direct parsing into real DOM trees.
tree-sharking
During compilation, the corresponding compilation module is imported for the API used. Similar to loading on demand
The last
Vue3 is a big improvement over VUE2 both in terms of performance and specification, and the advanced feature Composition Api is also a highlight of VUE 3. My understanding of VUE3 is only at the level of use. I will continue to dig and learn more features of VUE3 in the future. With the iterative update of technology, VUE3 is also the trend of The Times, refueling learning!