- Setup type: Function
The setup function is a new component option. It serves as an entry point for using composite apis within components. Call time:
When a component instance is created, setup is called immediately after the initial prop resolution. In terms of the life cycle, it is called before the beforeCreate hook. Template use: If Setup returns an object, the properties of that object are merged into the rendering context of the component template
<div>{{ count }} {{ object.foo }}</div> </template> <script> import { ref, reactive } from 'vue' export default { setup() { const count = ref(0) const object = reactive({ foo: Return {count, object}}} </script>Copy the code
Note that the refs returned from setup are automatically expanded when accessed in the template, so.value is not required in the template.
Setup can also return a render function that directly uses reactive state declared in the same scope:
export default {
setup() {
const count = ref(0)
const object = reactive({ foo: 'bar' })
return () => h('div', [count.value, object.foo])
}
Copy the code
Parameter This function takes the prop received as its first argument:
export default {
props: {
name: String
},
setup(props) {
console.log(props.name)
}
Copy the code
Note that this props object is reactive — that is, it is updated when a new props is passed in, and can be observed and responded to using watchEffect or Watch:
export default {
props: {
name: String
},
setup(props) {
watchEffect(() => {
console.log(`name is: ` + props.name)
})
}
Copy the code
However, don’t deconstruct the props object because it becomes unresponsive:
export default { props: { name: String }, setup({ name }) { watchEffect(() => { console.log(`name is: '+ name) // no response})}Copy the code
The props object is immutable to the user area code during development (a warning is issued if the user code tries to change it).
The second argument provides a context object that exposes a selection list of properties previously exposed on this:
setup(props, context) {
context.attrs
context.slots
context.emit
}
}
Copy the code
Attrs and slots are proxies for values on internal component instances. This ensures that they always display the latest values even after they are updated so that we can structurally decompose them without worrying about accessing old references:
Setup (props, {attrs}) {function onClick() {console.log(attrs.foo) // Guaranteed to be up to date}}}Copy the code