element-ui tag 组件源码分享

今日简单分享一下 tag 组件的源码实现,主要从以下三个方面来分享:

1、tag 组件页面结构

2、tag 组件属性

3、tag 组件方法

一、tag 组件页面结构

vue2 中使用 jsx 语法小结:

1.1 需要安装 babel-plugin-transform-vue-jsx 和 @vue/babel-helper-vue-jsx-merge-props 依赖

npm install --save-dev babel-plugin-transform-vue-jsx @vue/babel-helper-vue-jsx-merge-props

2、需要配置 babel 文件

{  
  "plugins": [  
    ["transform-vue-jsx", {  
      "functional": false  
    }]  
  ]  
}

3、使用 jsx

export default {  
  name: 'MyComponent',  
  props: {  
    msg: String  
  },  
  render(h) {  
    return (  
      <div>  
        <h1>{this.msg}</h1>  
        <button onClick={() => alert('Hello World!')}>Click Me</button>  
      </div>  
    );  
  }  
}

二、tag 组件方法

2.1 type 属性,类型,类型 string,success/info/warning/danger,无默认值。

2.2 closable 属性,是否可关闭,类型 boolean,默认 false。

组件使用部分:

展示效果:

2.3 disable-transitions 属性,是否禁用渐变动画,类型 boolean,默认 false。

组件使用:

<template>
  <el-tag
    v-for="(item) in tag"
    :key="item.id"
    type="success"
    :disable-transitions="item.id == 0"
    closable
    @close="handleClose(item)"
    >disable-transitions:{{item.id == 0}}</el-tag
  >
</template>

<script>
  export default {
    data() {
      return {
        tag: [
          {
            id: 0,
            title: 'tag 1',
          },
          {
            id: 1,
            title: 'tag 2',
          },
        ],
      };
    },
    methods: {
      handleClose({ id }) {
        const index = this.tag.findIndex((item) => item.id == id);
        this.tag.splice(index, 1);
      },
    },
  };
</script>

展示效果:

2.4 hit 属性,是否有边框描边,类型 boolean,默认 false。

组件使用:

<template>
  <el-tag
    v-for="(item) in tag"
    :key="item.id"
    type="success"
    :hit="item.id==0"
    >hit:{{item.id == 0}}</el-tag
  >
</template>

<script>
  export default {
    data() {
      return {
        tag: [
          {
            id: 0,
            title: 'tag 1',
          },
          {
            id: 1,
            title: 'tag 2',
          },
        ],
      };
    },
  };
</script>

展示效果:

2.5 color 属性,背景色,类型 string,无默认值。

组件使用:

展示效果:

2.6 size 属性,尺寸,类型 string,medium / small / mini,无默认值。

2.7 effect 属性,主题,类型 string,dark / light / plain,默认 light。

三、tag 组件方法

3.1 click 事件,点击 tag 时触发的事件。

3.2 close 事件,关闭 tag 时触发的事件。

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-02 15:56:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-02 15:56:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-02 15:56:02       82 阅读
  4. Python语言-面向对象

    2024-04-02 15:56:02       91 阅读

热门阅读

  1. AIGC重塑金融:AI大模型驱动的金融变革与实践

    2024-04-02 15:56:02       40 阅读
  2. Git 基本使用方法

    2024-04-02 15:56:02       33 阅读
  3. 【单例设计模式】

    2024-04-02 15:56:02       42 阅读
  4. Linux的信号栈的实现(1)

    2024-04-02 15:56:02       32 阅读
  5. redis-cli通过DUMP和SADD进行redis set数据类型迁移

    2024-04-02 15:56:02       34 阅读
  6. 2024.2.26力扣每日一题——二叉搜索树的范围和

    2024-04-02 15:56:02       34 阅读
  7. ubuntu install Python3

    2024-04-02 15:56:02       38 阅读
  8. Mapper接口

    2024-04-02 15:56:02       35 阅读
  9. Github 2024-03-29 开源项目日报Top10

    2024-04-02 15:56:02       39 阅读