您的位置:MYSQL中文网 > element 标签 ElementPlus Tag 标签

element 标签 ElementPlus Tag 标签

2023-04-17 06:30

element 标签 ElementPlus Tag 标签

element 标签 ElementPlus Tag 标签

element 标签

Tag 标签

用于标记和选择。

基础用法


由type属性来选择 tag 的类型,也可以通过color属性来自定义背景色。

<template>
  <el-tag>标签一</el-tag>
  <el-tag type="success">标签二</el-tag>
  <el-tag type="info">标签三</el-tag>
  <el-tag type="warning">标签四</el-tag>
  <el-tag type="danger">标签五</el-tag>
</template>

可移除标签


设置closable属性可以定义一个标签是否可移除。默认的标签移除时会附带渐变动画,如果不想使用,可以设置disable-transitions属性,它接受一个Boolean,true 为关闭。

<template>
  <el-tag v-for="tag in tags" :key="tag.name" closable :type="tag.type">
    {{tag.name}}
  </el-tag>
</template>

<script>
  export default {
    data() {
      return {
        tags: [
          { name: "标签一", type: "" },
          { name: "标签二", type: "success" },
          { name: "标签三", type: "info" },
          { name: "标签四", type: "warning" },
          { name: "标签五", type: "danger" },
        ],
      }
    },
  }
</script>

动态编辑标签

动态编辑标签可以通过点击标签关闭按钮后触发的 close 事件来实现


<template>
  <el-tag
    :key="tag"
    v-for="tag in dynamicTags"
    closable
    :disable-transitions="false"
    @close="handleClose(tag)"
  >
    {{tag}}
  </el-tag>
  <el-input
    class="input-new-tag"
    v-if="inputVisible"
    v-model="inputValue"
    ref="saveTagInput"
    size="small"
    @keyup.enter="handleInputConfirm"
    @blur="handleInputConfirm"
  >
  </el-input>
  <el-button v-else class="button-new-tag" size="small" @click="showInput"
    >+ New Tag</el-button
  >
</template>

<script>
  export default {
    data() {
      return {
        dynamicTags: ["标签一", "标签二", "标签三"],
        inputVisible: false,
        inputValue: "",
      }
    },
    methods: {
      handleClose(tag) {
        this.dynamicTags.splice(this.dynamicTags.indexOf(tag), 1)
      },

      showInput() {
        this.inputVisible = true
        this.$nextTick((_) => {
          this.$refs.saveTagInput.$refs.input.focus()
        })
      },

      handleInputConfirm() {
        let inputValue = this.inputValue
        if (inputValue) {
          this.dynamicTags.push(inputValue)
        }
        this.inputVisible = false
        this.inputValue = ""
      },
    },
  }
</script>
<style>
  .el-tag + .el-tag {
    margin-left: 10px;
  }
  .button-new-tag {
    margin-left: 10px;
    height: 32px;
    line-height: 30px;
    padding-top: 0;
    padding-bottom: 0;
  }
  .input-new-tag {
    width: 90px;
    margin-left: 10px;
    vertical-align: bottom;
  }
</style>

不同尺寸

Tag 组件提供除了默认值以外的三种尺寸,可以在不同场景下选择合适的按钮尺寸。


额外的尺寸:medium、small、mini,通过设置size属性来配置它们。

<template>
  <el-tag closable>默认标签</el-tag>
  <el-tag size="medium" closable>中等标签</el-tag>
  <el-tag size="small" closable>小型标签</el-tag>
  <el-tag size="mini" closable>超小标签</el-tag>
</template>

不同主题

Tag 组件提供了三个不同的主题:dark、light 和 plain


通过设置effect属性来改变主题,默认为 light

<template>
  <div class="tag-group">
    <span class="tag-group__title">Dark</span>
    <el-tag
      v-for="item in items"
      :key="item.label"
      :type="item.type"
      effect="dark"
    >
      {{ item.label }}
    </el-tag>
  </div>
  <div class="tag-group">
    <span class="tag-group__title">Plain</span>
    <el-tag
      v-for="item in items"
      :key="item.label"
      :type="item.type"
      effect="plain"
    >
      {{ item.label }}
    </el-tag>
  </div>
</template>

<script>
  export default {
    data() {
      return {
        items: [
          { type: "", label: "标签一" },
          { type: "success", label: "标签二" },
          { type: "info", label: "标签三" },
          { type: "danger", label: "标签四" },
          { type: "warning", label: "标签五" },
        ],
      }
    },
  }
</script>

类似复选框的标签

有时候因为业务需求,我们可能会需要用到类似复选框的标签,但是按钮式的复选框的样式又不满足需求,此时我们就可以用到 check-tag


check-tag 的基础使用方法,check-tag 提供的 API 非常简单

<template>
  <el-space>
    <el-check-tag checked>选中</el-check-tag>
    <el-check-tag @change="onChange" :checked="checked">点我切换</el-check-tag>
    <el-check-tag v-model:checked="checked">通过 v-model</el-check-tag>
  </el-space>
</template>

<script>
  export default {
    data() {
      return {
        checked: false,
      }
    },
    methods: {
      onChange(checked) {
        this.checked = checked
      },
    },
  }
</script>

Attributes

参数说明类型可选值默认值
type类型stringsuccess/info/warning/danger
closable是否可关闭booleanfalse
disable-transitions是否禁用渐变动画booleanfalse
hit是否有边框描边booleanfalse
color背景色string
size尺寸stringmedium / small / mini
effect主题stringdark / light / plainlight

Events

事件名称说明回调参数
click点击 Tag 时触发的事件
close关闭 Tag 时触发的事件

CheckTag Attributes

参数说明类型可选值默认值
v-model:checked / checked是否选中booleantrue/false

CheckTag Events

事件名称说明回调参数
change点击 Check Tag 时触发的事件checked
update:checked点击 Check Tag 时触发的事件checked


阅读全文
以上是MYSQL中文网为你收集整理的element 标签 ElementPlus Tag 标签全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 MYSQL中文网 mysqlcn.com 版权所有 联系我们
桂ICP备12005667号-29 Powered by CMS