vant/src/swipe-cell/README.md
2021-01-27 10:25:07 +08:00

4.1 KiB

SwipeCell

Install

import { createApp } from 'vue';
import { SwipeCell } from 'vant';

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

Usage

Basic Usage

<van-swipe-cell>
  <template #left>
    <van-button square type="primary" text="Select" />
  </template>
  <van-cell :border="false" title="Cell" value="Cell Content" />
  <template #right>
    <van-button square type="danger" text="Delete" />
    <van-button square type="primary" text="Collect" />
  </template>
</van-swipe-cell>

Custom Content

<van-swipe-cell>
  <van-card
    num="2"
    price="2.00"
    desc="Description"
    title="Title"
    class="goods-card"
    thumb="https://img01.yzcdn.cn/vant/cat.jpeg"
  />
  <template #right>
    <van-button square text="Delete" type="danger" class="delete-button" />
  </template>
</van-swipe-cell>

<style>
  .goods-card {
    margin: 0;
    background-color: @white;
  }

  .delete-button {
    height: 100%;
  }
</style>

Before Close

<van-swipe-cell :before-close="beforeClose">
  <template #left>
    <van-button square type="primary" text="Select" />
  </template>
  <van-cell :border="false" title="Cell" value="Cell Content" />
  <template #right>
    <van-button square type="danger" text="Delete" />
  </template>
</van-swipe-cell>
import { Dialog } from 'vant';

export default {
  setup() {
    const beforeClose = ({ position }) => {
      switch (position) {
        case 'left':
        case 'cell':
        case 'outside':
          return true;
        case 'right':
          return new Promise((resolve) => {
            Dialog.confirm({
              title: 'Are you sure to delete?',
            }).then(resolve);
          });
      }
    };

    return { beforeClose };
  },
};

API

Props

Attribute Description Type Default
name Identifier of SwipeCell number | string -
left-width Width of the left swipe area number | string auto
right-width Width of the right swipe area number | string auto
before-close Callback function before close (args) => boolean | Promise -
disabled Whether to disabled swipe boolean false
stop-propagation Whether to stop touchmove event propagation boolean false

Slots

Name Description
default custom content
left content of left scrollable area
right content of right scrollabe area

Events

Event Description Arguments
click Emitted when SwipeCell is clicked Click positon (left right cell outside)
open Emitted when SwipeCell is opened { position: 'left' | 'right' , name: string }
close Emitted when SwipeCell is closed { position: string , name: string }

beforeClose Params

Attribute Description Type
name Name string
position Click positon (left right cell outside) string
instance SwipeCell instance SwipeCell

Methods

Use ref to get SwipeCell instance and call instance methods.

Name Description Attribute Return value
open open SwipeCell position: left | right -
close close SwipeCell - -

Less Variables

How to use: Custom Theme.

Name Default Value Description
@switch-cell-padding-top @cell-vertical-padding - 1px -
@switch-cell-padding-bottom @cell-vertical-padding - 1px -
@switch-cell-large-padding-top @cell-large-vertical-padding - 1px -
@switch-cell-large-padding-bottom @cell-large-vertical-padding - 1px -