Categories: Vant4 教程

Vant4 PickerGroup 选择器组

介绍

用于结合多个 Picker 选择器组件,在一次交互中完成多个值的选择。

PickerGroup 中可以放置以下组件:

引入

通过以下方式来全局注册组件,更多注册方式请参考组件注册

import { createApp } from vue;
import { PickerGroup } from vant;

const app = createApp();
app.use(PickerGroup);

代码演示

选择日期时间

在 ​PickerGroup​ 的默认插槽中放置一个 ​DatePicker​ 组件和一个 ​TimePicker​ 组件,可以实现同时选择日期和时间的交互效果。

PickerGroup​ 会代替子组件来渲染统一的标题栏,这意味着子组件不会渲染单独的标题栏,与标题栏有关的 props 和 events 需要设置到 ​PickerGroup​ 上,比如 ​title​ 属性、​confirm​ 事件、​cancel​ 事件等,而子组件中与标题栏无关的属性和事件可以正常使用。

<van-picker-group
  title="预约日期"
  :tabs="[选择日期, 选择时间]"
  @confirm="onConfirm"
  @cancel="onCancel"
>
  <van-date-picker
    v-model="currentDate"
    :min-date="minDate"
    :max-date="maxDate"
  />
  <van-time-picker v-model="currentTime" />
</van-picker-group>
import { ref } from vue;
import { showToast } from vant;

export default {
  setup() {
    const currentDate = ref([2022, 06, 01]);
    const currentTime = ref([12, 00]);
    const onConfirm = () => {
      showToast(
        `${currentDate.value.join(/)} ${currentTime.value.join(:)}`
      );
    };
    const onCancel = () => {
      showToast(cancel);
    };

    return {
      minDate: new Date(2020, 0, 1),
      maxDate: new Date(2025, 5, 1),
      currentDate,
      currentTime,
    };
  },
};

选择日期范围

在 ​PickerGroup​ 的默认插槽中放置两个 ​DatePicker​ 组件,可以实现选择日期范围的交互效果。

<van-picker-group
  title="预约日期"
  :tabs="[开始日期, 结束日期]"
  @confirm="onConfirm"
  @cancel="onCancel"
>
  <van-date-picker v-model="startEnd" :min-date="minDate" :max-date="maxDate" />
  <van-date-picker v-model="endDate" :min-date="minDate" :max-date="maxDate" />
</van-picker-group>
import { ref } from vue;
import { showToast } from vant;

export default {
  setup() {
    const startDate = ref([2022, 06, 01]);
    const endDate = ref([2023, 06, 01]);

    const onConfirm = () => {
      showToast(`${startDate.value.join(/)} ${endDate.value.join(/)}`);
    };
    const onCancel = () => {
      showToast(cancel);
    };

    return {
      minDate: new Date(2020, 0, 1),
      maxDate: new Date(2025, 5, 1),
      endDate,
      startDate,
    };
  },
};

选择时间范围

在 ​PickerGroup​ 的默认插槽中放置两个 ​TimePicker​ 组件,可以实现选择时间范围的交互效果。

<van-picker-group
  title="预约时间"
  :tabs="[开始时间, 结束时间]"
  @confirm="onConfirm"
  @cancel="onCancel"
>
  <van-time-picker v-model="startEnd" />
  <van-time-picker v-model="endDate" />
</van-picker-group>
import { ref } from vue;
import { showToast } from vant;

export default {
  setup() {
    const startTime = ref([12, 00]);
    const endTime = ref([12, 00]);

    const onConfirm = () => {
      showToast(`${startTime.value.join(:)} ${endTime.value.join(:)}`);
    };
    const onCancel = () => {
      showToast(cancel);
    };

    return {
      endTime,
      startTime,
    };
  },
};

API

Props

参数 说明 类型 默认值
title 顶部栏标题 string
confirm-button-text 确认按钮文字 string 确认
cancel-button-text 取消按钮文字 string 取消

Slots

名称 说明 参数
toolbar 自定义整个顶部栏的内容
title 自定义标题内容
confirm 自定义确认按钮内容
cancel 自定义取消按钮内容

类型定义

组件导出以下类型定义:

import type { PickerGroupProps } from vant;
andy

前端小白,在Web176教程网这个平台跟大家一起学习,加油!

Share
Published by
andy

Recent Posts

了解 ChatGPT 如何维护上下文

对话中的语境概念至关重要,因为…

4 天 ago

GenAI:如何通过快速压缩技术降低成本

在本文中,我们将探讨在开发早期…

1 周 ago

vue:页面注入js修改input值

一般会直接这样写: let z…

2 周 ago

聊聊vue3中的defineProps

在Vue 3中,defineP…

3 周 ago

在 Chrome 中删除、允许和管理 Cookie

您可以选择删除现有 Cooki…

4 周 ago

自定义指令:聊聊vue中的自定义指令应用法则

今天我们来聊聊vue中的自定义…

1 月 ago