Skip to content

间距 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
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
Primary
Block
start
Primary
Block
end
Primary
Block
baseline
Primary
Block
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区域总宽度,单位 pxstring | number'auto'
align垂直排列方式'stretch' | 'start' | 'end' | 'center' | 'baseline''start'
vertical是否为垂直布局booleanfalse
gap间距大小,数组时表示: [水平间距, 垂直间距]number | number[] | 'small' | 'middle' | 'large''middle'
wrap是否自动换行,仅在 horizontal 时有效booleantrue

Slots

名称说明类型
default自定义内容v-slot:default

Released under the MIT License.