91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue?Element?UI擴展內容過長如何使用tooltip顯示

發布時間:2022-06-02 18:56:15 來源:億速云 閱讀:1105 作者:iii 欄目:開發技術

本篇內容主要講解“vue Element UI擴展內容過長如何使用tooltip顯示”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“vue Element UI擴展內容過長如何使用tooltip顯示”吧!

    1. 介紹

    Tooltip常用于展示鼠標 hover 時的提示信息。

    而在實際過程中,有這么一個需求:只有文字內容排不下,出現省略號,才需要顯示tooltip的提示內容。

    本文章的思路是通過一個自定義指令實現如下效果:姓名字段過長時才顯示tooltip

    vue?Element?UI擴展內容過長如何使用tooltip顯示

    2. element-ui(vue2版本)

    2.1 注冊指令

    1) akTooltipAutoShow.js

    說明:注冊了一個名稱為 'ak-tooltip-auto-show' 的指令。會根據內容進行判斷是否展示tooltip。

    import Vue from 'vue';
    import { on, off, getStyle } from 'element-ui/src/utils/dom';
    /**
     * ak-tooltip-auto-show
     * 當text沒有被折疊時,不顯示tooltip
     */
    Vue.directive('ak-tooltip-auto-show', {
      inserted: function (el, binding, vnode) {
        el.addEventListener('mouseenter', function (e) {
          let defalutSilent = !!Vue.config.silent;
          Vue.config.silent = true;
          vnode.componentInstance.disabled = true;
          const range = document.createRange();
          range.setStart(el, 0);
          range.setEnd(el, el.childNodes.length);
          const rangeWidth = Math.round(range.getBoundingClientRect().width);
          const padding = (parseInt(getStyle(el, 'paddingLeft'), 10) || 0) + (parseInt(getStyle(el, 'paddingRight'), 10) || 0);
          if (rangeWidth + padding > el.offsetWidth || el.scrollWidth > el.offsetWidth) {
            vnode.componentInstance.disabled = false;
          }
          Vue.config.silent = defalutSilent;
        });
      }
    });

    2.2 使用

    說明:使用<el-tooltip v-ak-tooltip-auto-show>包囊展示的內容。

      <div class="details-inner__row">
        <span class="details-inner__row-name">姓名:</span>
        <el-tooltip placement="top" effect="dark" :content="item.name" v-ak-tooltip-auto-show>
            <span class="details-inner__row-value">{{item.name}}</span>
        </el-tooltip>
    </div>
    // css
    .details-inner__row-value {
      width: 80%;
      display: inline-block;
      white-space: nowrap;
      text-overflow: ellipsis;
      overflow: hidden;
    }

    3. element-plus(vue3版本)

    3.1 注冊指令

    1) akTooltipAutoShow.js

    說明

    注冊了一個名稱為 'ak-tooltip-auto-show' 的指令。會根據內容進行判斷是否展示tooltip。

    注意

    因為element-plus與之前的element-ui不一樣,在element-plus(vue3版本)中是 <展示組件>包含<el-tooltip>的,所以代碼中需要在<展示組件>內查找<el-tooltop>。

    import { getStyle } from 'element-plus/lib/utils/dom/index';
    /**
     * show-overflow-tooltip for text
     * 當text沒有被折疊時,不顯示tooltip
     */
    const akTooltipAutoShow = {
      created(el, binding, vnode) {
        let tooltipNode = vnode.children.find((childrenCmpt) => childrenCmpt.component?.type.name == 'ElTooltip');
        if (tooltipNode) {
          let { content } = tooltipNode.props;
          if (content && ['添加', '編輯', '刪除','查看'].includes(content)) {
            el.addEventListener('click', function (e) {
              let defalutDisabled = tooltipNode.component.props.disabled;
              if (!defalutDisabled) {
                tooltipNode.component.props.disabled = true;
                setTimeout(() => {
                  tooltipNode.component.props.disabled = defalutDisabled;
                }, 200);
              }
            });
          } else {
            el.addEventListener('mouseenter', (e) => {
              tooltipNode.component.props.disabled = true;
              const range = document.createRange();
              range.setStart(el, 0);
              range.setEnd(el, el.childNodes.length);
              const rangeWidth = Math.round(range.getBoundingClientRect().width);
              const padding = (parseInt(getStyle(el, 'paddingLeft'), 10) || 0) + (parseInt(getStyle(el, 'paddingRight'), 10) || 0);
              if (rangeWidth + padding > el.offsetWidth || el.scrollWidth > el.offsetWidth) {
                tooltipNode.component.props.disabled = false;
              }
            });
          }
        }
      }
    };
    export default akTooltipAutoShow;
    2) 進行局部或全局注冊
    // main.js
    const app = createApp(App);
    import akTooltipAutoShow from './akTooltipAutoShow.js';
    app.directive('ak-tooltip-auto-show', akTooltipAutoShow);

    3.2 使用

    說明:因element-plus(vue3版本)本身不提供 root element,所以需要把此指令放到<el-tooltip>的父級組件。

    <div class="details-inner__row">
      <span class="details-inner__row-name">姓名:</span>
      <span class="details-inner__row-value" v-ak-tooltip-auto-show>
        <el-tooltip placement="top-end" :content="item.name">{{item.name}}</el-tooltip>
      </span>
    </div>
    // css
    .details-inner__row-value {
      width: 80%;
      display: inline-block;
      white-space: nowrap;
      text-overflow: ellipsis;
      overflow: hidden;
    }

    到此,相信大家對“vue Element UI擴展內容過長如何使用tooltip顯示”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    平武县| 桐乡市| 兴安县| 辽中县| 泰宁县| 阿克陶县| 长武县| 永福县| 通城县| 洛宁县| 平利县| 平度市| 金堂县| 藁城市| 龙海市| 雅安市| 眉山市| 砚山县| 梁河县| 勐海县| 岑溪市| 桐柏县| 京山县| 都江堰市| 南岸区| 隆回县| 微山县| 赣州市| 白山市| 温泉县| 阳朔县| 诸暨市| 梁河县| 杨浦区| 礼泉县| 安乡县| 赤城县| 竹山县| 两当县| 泰州市| 朝阳市|