佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 純css實現(xiàn)(無腳本)Html指令式tooltip文字提示效果

純css實現(xiàn)(無腳本)Html指令式tooltip文字提示效果

熱門標(biāo)簽:使用U盤裝系統(tǒng) 檢查注冊表項 百度競價點擊價格的計算公式 硅谷的囚徒呼叫中心 阿里云 智能手機 網(wǎng)站建設(shè) 美圖手機

 

分析執(zhí)行流程 鼠標(biāo)移入節(jié)點 檢測是該節(jié)點是否存在開啟實現(xiàn) tooltip 實現(xiàn)的標(biāo)識(類名,屬性等) 檢測主題、位置(類名,屬性等) 生成 / 顯示氣泡 借鑒他人

讓我們先來看看 element-ui的tooltip 樣式

很明顯, 氣泡的位置 是通過 javascript腳本 加上去的

 

不多逼逼,讓我們來定幾個期望 不用javascript腳本, 純css 實現(xiàn) 不用添加新元素**(用after、before偽元素)** 不用類名匹配,直接用屬性選擇器**([attr])** 支持默認(rèn)樣式**(標(biāo)簽沒定義主題、位置的時候)** 指令式**(直接在標(biāo)簽定義即可,接下來交給css匹配)** 實現(xiàn)氣泡的 主題、位置sass 預(yù)處理器開發(fā)(看不懂的同學(xué)可以轉(zhuǎn)換成 css ) html定義指令規(guī)范

指令式聲明

<button tooltip='我是內(nèi)容鴨' effect='light' placement='top-left'>上左</button>
  • tooltip — 氣泡顯示的 內(nèi)容 ;
  • effect — 氣泡的 主題 (dark / light),默認(rèn)dark;
  • placement — 氣泡相對于父元素的 位置 (top / top-left/ top-right / right / right-top/ right-bottom...),默認(rèn)top;
     

先寫幾個按鈕

樣式借鑒element-ui

<div class="container">
  <div class="top">
    <button tooltip="上邊" placement="top-left" effect="light">上左</button>
    <button tooltip="上左上左" placement="top">上邊</button>
    <button tooltip="上右" placement="top-right">上右</button>
  </div>
  <div class="left">
    <button tooltip="左上左上左上左上左上左上左上左上左上左上" placement="left-top">左上</button>
    <button tooltip="左邊" placement="left" effect="light">左邊</button>
    <button tooltip="左右" placement="left-bottom">左下</button>
  </div>
  <div class="right">
    <button tooltip="右上右上右上右上右上右上右上右上" placement="right-top">右上</button>
    <button tooltip="右邊" placement="right" effect="light">右邊</button>
    <button tooltip="右下" placement="right-bottom">右下</button>
  </div>
  <div class="bottom">
    <button tooltip="下左下左" placement="bottom-left">下左</button>
    <button tooltip="下邊" placement="bottom" effect="light">下邊</button>
    <button tooltip="下右" placement="bottom-right">下右</button>
  </div>
</div>

css核心代碼邏輯實現(xiàn)

hover監(jiān)聽鼠標(biāo)移入、移出,**[tooltip]**匹配有該屬性的標(biāo)簽, after 為氣泡, before 為三角形

/* 匹配有tooltip屬性的元素 */
[tooltip] {
  position: relative;
  /* 氣泡默認(rèn)樣式 */
  &::after {
    display: none;
    content: attr(tooltip);
  }
  /* 三角形默認(rèn)樣式 */
  &::before {
    display: none;
    content: '';
  }
  /* 鼠標(biāo)移入該元素,顯示氣泡、三角形 */
  &:hover {
    &::after {
      display: block;
    }
    &::before {
      display: block;
    }
  }
}

現(xiàn)在鼠標(biāo)移入之后便有效果

為了方便看到效果,測試可以把氣泡、三角形默認(rèn)為block

/* 氣泡默認(rèn)樣式 */
&::after {
  display: block;
  content: attr(tooltip);
}

/* 三角形默認(rèn)樣式 */
&::before {
  display: block;
  content: '';
}

目前效果如下

 

設(shè)置氣泡、三角形的默認(rèn)樣式

核心顯示當(dāng)然是設(shè)置絕對定位了

/* 氣泡默認(rèn)樣式 */
&::after {
  display: block;
  content: attr(tooltip);
  position: absolute;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 8px 15px;
  max-width: 200px;
  border-radius: 4px;
  box-shadow: 0 10px 20px -5px rgba(0, 0, 0, 0.4);
  z-index: 100;
  @extend .tooltip-theme-dark; /* 繼承默認(rèn)主題(黑底白字) */
 }

/* 三角形默認(rèn)樣式 */
&::before {
  display: block;
  content: '';
  position: absolute;
  border: 5px solid transparent;
  z-index: 100;
  @extend .triangle-theme-dark; /* 繼承默認(rèn)主題(黑底) */
}

目前效果如下

 

定制氣泡、三角形主題色

定義好各兩種主題

$white: #fff;
$black: #313131;

/* 氣泡主題 */
.tooltip-theme-dark {
  color: $white;
  background-color: $black;
}

.tooltip-theme-light {
  color: $black;
  background-color: $white;
  border: 1px solid $black;
}

/* 三角形主題 */
.triangle-theme-dark {
  border-top-color: $black;
}

.triangle-theme-light {
  border-top-color: $black; /* 暫時跟dark一樣 */
}

定制氣泡、三角形位置(只示例一個方向)

/* 氣泡位置 */

/*----上----*/
.tooltip-placement-top {
  bottom: calc(100% + 10px);
  left: 50%;
  transform: translate(-50%, 0);
}

.tooltip-placement-top-right {
  bottom: calc(100% + 10px);
  left: 100%;
  transform: translate(-100%, 0)
}

.tooltip-placement-top-left {
  bottom: calc(100% + 10px);
  left: 0;
  transform: translate(0, 0)
}

/* 三角形位置 */

/*----上----*/
.triangle-placement-top {
  bottom: calc(100% + 5px);
  left: 50%;
  transform: translate(-50%, 0);
}

.triangle-placement-top-left {
  bottom: calc(100% + 5px);
  left: 10px;
}

.triangle-placement-top-right {
  bottom: calc(100% + 5px);
  right: 10px;
}

捕捉位置、主題

這里也算最核心的代碼了,用屬性選擇器來匹配標(biāo)簽上的值,然后設(shè)置不同的樣式

匹配氣泡、三角形主題

&[effect="light"] {
  &::after {
    @extend .tooltip-theme-light;
  }

  &::before {
    @extend .triangle-theme-light;
  }
}

匹配氣泡、三角形位置,12種位置

@each $placement in top,top-right,top-left,
right,right-top,right-bottom,
bottom,bottom-right,bottom-left,
left,left-top,left-bottom {
  &[placement="#{$placement}"] {
    &::after {
      @extend .tooltip-placement-#{$placement};
    }

    &::before {
      @extend .triangle-placement-#{$placement};
    }
  }
}

標(biāo)簽不存在placement 屬性 / 為空的時候,默認(rèn)繼承top位置

&:not([placement]),
&[placement=""] {
  &::after {
    @extend .tooltip-placement-top;
  }

  &::before {
    @extend .triangle-placement-top;
  }
}

目前效果如下

讓我們把文字放長,把氣泡、三角形的默認(rèn)樣式加上display:none看看

 加個動畫

分四個方向,上下左右,四個動畫

@keyframes anime-top {
  from {
    opacity: .5;
    bottom: 150%;
  }
}

@keyframes anime-bottom {
  from {
    opacity: .5;
    top: 150%;
  }
}

@keyframes anime-left {
  from {
    opacity: .5;
    right: 150%;
  }
}

@keyframes anime-right {
  from {
    opacity: .5;
    left: 150%;
  }
}

匹配氣泡位置從而來確定執(zhí)行哪個動畫,用**[attr^=]**選擇,如 上左、上右也能匹配到

/* 設(shè)置動畫 */
@each $placement in top,
 right,
bottom,
left {
  &[placement^="#{$placement}"] {

    &::after,
    &::before {
      animation: anime-#{$placement} 300ms ease-out forwards;
    }
  }
}

最終效果如下

附上codepen地址  codepen.io/anon/pen/yR …

總結(jié)

以上所述是小編給大家介紹的純css實現(xiàn)(無腳本)Html指令式tooltip文字提示效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

標(biāo)簽:湖北 賀州 湘潭 山南 黃山 懷化 煙臺 通遼

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《純css實現(xiàn)(無腳本)Html指令式tooltip文字提示效果》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    大安市| 黄冈市| 温州市| 称多县| 玉树县| 永顺县| 湖州市| 互助| 习水县| 黄梅县| 明星| 永顺县| 萨嘎县| 新昌县| 万州区| 双鸭山市| 迁安市| 丹东市| 雷波县| 龙井市| 平果县| 南和县| 连江县| 许昌县| 广安市| 永寿县| 灵寿县| 濮阳市| 兰考县| 滨州市| 米易县| 德格县| 岳阳市| 会昌县| 永年县| 巴塘县| 休宁县| 酉阳| 怀来县| 五河县| 六枝特区|