`useVModel` 工具函数可实现双向绑定,简化手工操作。

1,715 阅读1分钟

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>