当前位置: 首页 > article >正文

Vue 3 中的 el-tooltip 详解:语法、示例及与其他框架对比

目录

  • 前言
  • 1. 基本知识
  • 2. 实战Demo

前言

🤟 找工作,来万码优才:👉 #小程序://万码优才/r6rqmzDaXpYkJZF

1. 基本知识

el-tooltip 是 Element Plus(Vue 3 组件库)中的一个用于提示的组件,它可以在用户悬停或点击元素时显示额外信息。通常用于按钮、图标等需要提供额外描述的地方

基本语法如下:

<el-tooltip content="提示内容" placement="top">
  <el-button>悬停查看</el-button>
</el-tooltip>

主要属性如下:

属性名说明类型默认值
content显示的提示内容string
placement提示框出现的位置(top, right, bottom, left等)stringbottom
trigger触发方式(hover, click, focus, manual)stringhover
effect主题样式(dark 或 light)stringdark
disabled是否禁用 tooltipbooleanfalse
show-after延迟显示(毫秒)number0
hide-after延迟隐藏(毫秒)number0

基本的Demo:

<template>
  <div>
    <el-tooltip content="这是一个提示" placement="top">
      <el-button type="primary">悬停查看</el-button>
    </el-tooltip>

    <el-tooltip content="点击触发" placement="right" trigger="click">
      <el-button type="success">点击查看</el-button>
    </el-tooltip>

    <el-tooltip content="焦点触发" placement="bottom" trigger="focus">
      <el-input placeholder="输入框提示"></el-input>
    </el-tooltip>

    <el-tooltip content="手动触发" v-model="visible">
      <el-button @click="visible = !visible">手动切换</el-button>
    </el-tooltip>
  </div>
</template>

<script setup>
import { ref } from 'vue';
const visible = ref(false);
</script>

el-tooltip 与其他框架对比

框架/库组件名主要差异点
Element Plusel-tooltip基于 Vue 3,支持 v-model 控制显示状态,可搭配 el-button、el-input 等
Ant Design Vuea-tooltip需使用 title 作为提示内容,placement 选项更丰富
Bootstrap Vueb-tooltip依赖 Popper.js,使用 target 绑定元素
Vuetifyv-tooltip通过 activator 绑定目标元素,可结合 v-model 控制

结合代码进行理解:

<template>
  <el-table :data="tooltipData" border style="width: 100%">
    <el-table-column prop="framework" label="框架" width="180"></el-table-column>
    <el-table-column prop="component" label="组件名" width="180"></el-table-column>
    <el-table-column prop="difference" label="主要差异点"></el-table-column>
  </el-table>

  <el-tooltip content="Element Plus Tooltip" placement="top">
    <el-button type="primary">Element Plus</el-button>
  </el-tooltip>
  
  <a-tooltip title="Ant Design Vue Tooltip">
    <a-button type="primary">Ant Design Vue</a-button>
  </a-tooltip>

  <b-tooltip target="bootstrapBtn" title="Bootstrap Vue Tooltip"></b-tooltip>
  <b-button id="bootstrapBtn" variant="primary">Bootstrap Vue</b-button>

  <v-tooltip bottom>
    <template v-slot:activator="{ on, attrs }">
      <v-btn color="primary" v-bind="attrs" v-on="on">Vuetify</v-btn>
    </template>
    <span>Vuetify Tooltip</span>
  </v-tooltip>
</template>

<script setup>
import { ref } from 'vue';

const tooltipData = ref([
  { framework: 'Element Plus', component: 'el-tooltip', difference: '支持 Vue 3,`v-model` 控制显示' },
  { framework: 'Ant Design Vue', component: 'a-tooltip', difference: '使用 `title` 设置提示内容' },
  { framework: 'Bootstrap Vue', component: 'b-tooltip', difference: '基于 Popper.js,需要 `target` 绑定' },
  { framework: 'Vuetify', component: 'v-tooltip', difference: '通过 `activator` 绑定目标元素' }
]);
</script>

总的来说:

  • el-tooltip 适用于 Vue 3,可与 Element Plus 组件无缝集成
  • 相比其他框架,如 a-tooltip(Ant Design Vue)和 b-tooltip(Bootstrap Vue),el-tooltip 具有更直观的 v-model 绑定和自定义选项
  • v-tooltip(Vuetify)更适合 Material Design 风格,并支持 activator 绑定

2. 实战Demo

原先实战引用过:Vue3优化表单标签与布局,解决文字过长问题(附Demo)

<el-tooltip v-if="showColor"
            effect="dark"
            :content="$t('navbar.color')"
            placement="bottom">
  <div class="top-bar__item">
    <top-color></top-color>
  </div>
</el-tooltip>
<el-tooltip v-if="showDebug"
            effect="dark"
            :content="logsFlag?$t('navbar.bug'):logsLen+$t('navbar.bugs')"
            placement="bottom">
  <div class="top-bar__item">
    <top-logs></top-logs>
  </div>
</el-tooltip>
<el-tooltip v-if="showLock"
            effect="dark"
            :content="$t('navbar.lock')"
            placement="bottom">
  <div class="top-bar__item">
    <top-lock></top-lock>
  </div>
</el-tooltip>
<el-tooltip v-if="showTheme"
            effect="dark"
            :content="$t('navbar.theme')"
            placement="bottom">
  <div class="top-bar__item top-bar__item--show">
    <top-theme></top-theme>
  </div>
</el-tooltip>
<el-tooltip effect="dark"
            :content="$t('navbar.notice')"
            placement="bottom">
  <div class="top-bar__item top-bar__item--show">
    <top-notice></top-notice>
  </div>
</el-tooltip>
<el-tooltip effect="dark"
            :content="$t('navbar.language')"
            placement="bottom">
  <div class="top-bar__item top-bar__item--show">
    <top-lang></top-lang>
  </div>
</el-tooltip>
<el-tooltip v-if="showFullScren"
            effect="dark"
            :content="isFullScren?$t('navbar.screenfullF'):$t('navbar.screenfull')"
            placement="bottom">
  <div class="top-bar__item">
    <i :class="isFullScren?'icon-tuichuquanping':'icon-quanping'"
       @click="handleScreen"></i>
  </div>
</el-tooltip>

基本方法如下:

handleScreen() {
  fullscreenToggel();
},
setCollapse() {
  this.$store.commit("SET_COLLAPSE");
},
setScreen() {
  this.$store.commit("SET_FULLSCREN");
},
logout() {
  this.$confirm(this.$t("logoutTip"), this.$t("tip"), {
    confirmButtonText: this.$t("submitText"),
    cancelButtonText: this.$t("cancelText"),
    type: "warning"
  }).then(() => {
    this.$store.dispatch("LogOut").then(() => {
      resetRouter();
      this.$router.push({path: "/login"});
    });
  });
}

截图如下:

在这里插入图片描述


http://www.kler.cn/a/534559.html

相关文章:

  • 洛谷网站: P3029 [USACO11NOV] Cow Lineup S 题解
  • 3. k8s二进制集群之负载均衡器高可用部署
  • Linux中的基本指令(二)
  • JavaScript前后端交互-AJAX/fetch
  • ThreadLocal
  • ubuntu 网络管理--wpa_supplicant、udhcpc
  • 谈谈对IOC的理解
  • 反向代理模块anns
  • 笔记:新能源汽车零部件功率级测试怎么进行?
  • 文心一言指令词宝典之职场效率篇
  • Java 大视界 -- Java 大数据在智慧文旅中的应用与体验优化(74)
  • 快速幂,错位排序笔记
  • 【字节青训营-6】:Gorm的基础使用
  • DeepSeek与llama本地部署(含WebUI)
  • ESXI虚拟机中部署docker会降低服务器性能
  • C# 压缩图片并保存到本地
  • Android性能优化系列——卡顿优化
  • 【C++】指针的基础概念与应用解析
  • tkvue 入门,像写html一样写tkinter
  • uniapp小程序自定义中间凸起样式底部tabbar
  • 记录使用libvirt创建虚拟机、自定义qcow2镜像
  • 图像分割中根据mask的ROI,去除mask和image中没有勾画ROI层数以外的图像
  • 数据库技术基础
  • Certum OV企业型通配符SSL
  • 常用工具类——Collections集合框架
  • c++ 基础 计算机的内存和寻址机制