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,如若转载,请注明出处:https://www.web176.com/vant4/18922.html

(0)
打赏 支付宝 支付宝 微信 微信
andy的头像andy
上一篇 2023年4月28日
下一篇 2023年4月28日

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注