目录
1. 自动导入 Vue3 APIs —— unplugin-auto-import/vite
2.4 v-model 中的自定义修饰符 modelModifiers
Vue3 中的 APIs 无需导入,可直接使用
使用示例:
- // 使用前
- import { computed, ref } from 'vue'
- const count = ref(0)
- const doubled = computed(() => count.value * 2)
-
- // 使用后
- const count = ref(0)
- const doubled = computed(() => count.value * 2)
安装命令:
npm i -D unplugin-auto-import
vite 配置:
-
- import { defineConfig } from 'vite'
- import vue from '@vitejs/plugin-vue'
- // 注意:不能缺少 /vite
- import AutoImport from 'unplugin-auto-import/vite'
-
- // https://vitejs.dev/config/
-
- export default defineConfig({
- plugins: [vue(), AutoImport({
- imports:['vue'],
- dts:"src/auto-import.d.ts"
- })]
- })
v-model 是一个语法糖,通过 props + emit 组合而成
props:value -> modelValue;
emits:input -> update:modelValue;
v-bind 的 .sync 修饰符和组件的 model 选项已移除
新增 支持多个v-model
新增 支持自定义 修饰符 Modifiers
在父组件中引入子组件,并给子组件添加 v-model 的绑定值 show
注意:此处的 v-model 只有一个,所以后面不用跟具体的名字,比如 v-model:title
- <button @click="show = !show">是否展示 -- {{ show }}button>
- <Dialog v-model="show">Dialog>
-
- <script setup lang='ts'>
- import Dialog from "./components/Dialog/index.vue";
- import { ref } from 'vue'
-
- const show = ref(false)
- script>
在子组件中定义 v-model 需要的 props:
如果没有定义名字(比如 v-model:title 表示有名字),则使用默认写法 —— modelValue
在子组件中定义 v-model 需要的 emits:
如果没有定义名字(比如 v-model:title 表示有名字),则使用默认写法 —— update:modelValue
- <div v-if='propData.modelValue'>
- <div class="dialog-header">
- <div @click="closeDialog">关闭按钮div>
- div>
- <div class="dialog-content">
- 内容
- div>
- div>
-
- <script setup lang='ts'>
- type Props = {
- modelValue:boolean
- }
-
- const propData = defineProps<Props>()
-
- const emit = defineEmits(['update:modelValue'])
-
- // 关闭事件
- const closeDialog = () => {
- // 双向绑定更新值
- emit('update:modelValue', false)
- }
- script>
在父组件中引入子组件,并给子组件添加 v-model 的绑定值 show
注意:此处的 v-model 有多个:
- <button @click="show = !show">是否展示 -- {{ show }} -- {{ title }}button>
- <Dialog v-model="show" v-model:title="dialogTitle">Dialog>
-
- <script setup lang='ts'>
- import Dialog from "./components/Dialog/index.vue";
- import { ref } from 'vue'
-
- const show = ref(false)
- const dialogTitle = ref('弹框名字')
- script>
在子组件中定义 v-model 需要的 props:
在子组件中定义 v-model 需要的 emits:
- <div v-if='propData.modelValue'>
- <div class="dialog-header">
- <div @click="closeDialog">关闭按钮div>
- div>
- <div class="dialog-content">
- 内容
- div>
- div>
-
- <script setup lang='ts'>
- type Props = {
- modelValue: boolean,
- title: string,
- }
-
- const propData = defineProps<Props>()
-
- const emit = defineEmits(['update:modelValue', 'update:title'])
-
- // 关闭事件
- const closeDialog = () => {
- // 双向绑定更新值
- emit('update:modelValue', false)
- emit('update:title','双向绑定改变 title')
- }
- script>
添加到 v-model 后边的修饰符,将通过 props 中的 modelModifiers 提供给组件
举个栗子~
在父组件中,给 v-model 添加修饰符 .islang —— v-model:title.islang
- <button @click="show = !show">是否展示 -- {{ show }} -- {{ title }}button>
- <Dialog v-model="show" v-model:title.islang="dialogTitle">Dialog>
-
- <script setup lang='ts'>
- import Dialog from "./components/Dialog/index.vue";
- import { ref } from 'vue'
-
- const show = ref(false)
- const dialogTitle = ref('弹框名字')
- script>
在子组件中,使用 titleModifiers 接收 v-model 修饰符,并在更新 title 值时,使用 自定义修饰符,判断应该返回什么值
-