vue3中的v-model可以用useVModel
工具函数去实现
// import { toRef } from 'vue'
import { useVModel } from '@vueuse/core'
export default {
name: 'Checkbox',
props: {
modelValue: {
type: Boolean,
default: false
}
},
setup(props, { emit }) {
const checked = useVModel(props, 'modelValue', emit)
return { checked }
}
// setup(props, { emit }) {
// // 父组件将原始的状态值传递给子组件并且保证响应式能力
// const checked = toRef(props, 'modelValue')
// const toggleSelect = () => {
// // checked.value = !checked.value
// // 修改父组件中的modelValue的值
// emit('update:modelValue', !checked.value)
// }
// return { checked, toggleSelect }
// }
}
</script>