间距 Space 
设置组件之间的间距
何时使用 
避免组件紧贴在一起,拉开统一的空间
- 适合行内元素的水平间距
 - 可以设置各种水平对齐方式
 
基本使用 
 Space 
Button
Show Code
vue
<template>
  <Space align="center">
    Space
    <Button type="primary">Button</Button>
    <Popconfirm title="Are you sure delete this task?" ok-text="Yes" cancel-text="No">
      <Button>Confirm</Button>
    </Popconfirm>
  </Space>
</template>设置间距 
small
middle
large
customize
Primary
Default
Dashed
Link
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const gapOptions = ref([
  {
    label: 'small',
    value: 'small'
  },
  {
    label: 'middle',
    value: 'middle'
  },
  {
    label: 'large',
    value: 'large'
  },
  {
    label: 'customize',
    value: 'customize'
  }
])
const gapSize = ref('middle')
const customGapSize = ref(16)
</script>
<template>
  <Flex vertical>
    <Radio :options="gapOptions" v-model:value="gapSize" />
    <Slider v-if="gapSize === 'customize'" v-model:value="customGapSize" />
    <Space :gap="gapSize !== 'customize' ? gapSize : customGapSize">
      <Button type="primary">Primary</Button>
      <Button>Default</Button>
      <Button type="dashed">Dashed</Button>
      <Button type="link">Link</Button>
    </Space>
  </Flex>
</template>垂直间距 
Card
Card content
Card content
Card
Card content
Card content
Show Code
vue
<template>
  <Space vertical>
    <Card title="Card" style="width: 300px">
      <p>Card content</p>
      <p>Card content</p>
    </Card>
    <Card title="Card" style="width: 300px">
      <p>Card content</p>
      <p>Card content</p>
    </Card>
  </Space>
</template>对齐 
 center Block
Primary
 start Block
Primary
 end Block
Primary
 baseline Block
Primary
Show Code
vue
<template>
  <div class="space-align-container">
    <div class="space-align-block">
      <Space align="center">
        center
        <Button type="primary">Primary</Button>
        <span class="mock-block">Block</span>
      </Space>
    </div>
    <div class="space-align-block">
      <Space align="start">
        start
        <Button type="primary">Primary</Button>
        <span class="mock-block">Block</span>
      </Space>
    </div>
    <div class="space-align-block">
      <Space align="end">
        end
        <Button type="primary">Primary</Button>
        <span class="mock-block">Block</span>
      </Space>
    </div>
    <div class="space-align-block">
      <Space align="baseline">
        baseline
        <Button type="primary">Primary</Button>
        <span class="mock-block">Block</span>
      </Space>
    </div>
  </div>
</template>
<style lang="less" scoped>
.space-align-container {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
}
.space-align-block {
  margin: 8px 4px;
  border: 1px solid #40a9ff;
  padding: 4px;
  flex: none;
}
.space-align-block .mock-block {
  display: inline-block;
  padding: 32px 8px 16px;
  background: rgba(150, 150, 150, 0.2);
}
</style>自动换行 
Button
Button
Button
Button
Button
Button
Button
Button
Button
Button
Button
Button
Button
Button
Button
Button
Show Code
vue
<template>
  <Space :gap="[8, 16]">
    <template v-for="n in 16" :key="n">
      <Button type="primary">Button</Button>
    </template>
  </Space>
</template>APIs 
Space 
| 参数 | 说明 | 类型 | 默认值 | 
|---|---|---|---|
| width | 区域总宽度,单位 px | string | number | 'auto' | 
| align | 垂直排列方式 | 'stretch' | 'start' | 'end' | 'center' | 'baseline' | 'start' | 
| vertical | 是否为垂直布局 | boolean | false | 
| gap | 间距大小,数组时表示: [水平间距, 垂直间距] | number | number[] | 'small' | 'middle' | 'large' | 'middle' | 
| wrap | 是否自动换行,仅在 horizontal 时有效 | boolean | true | 
Slots 
| 名称 | 说明 | 类型 | 
|---|---|---|
| default | 自定义内容 | v-slot:default |