国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

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

2024-08-26 00:21:33
字體:
供稿:網(wǎng)友
css,Html,tooltip,文字提示 

 

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

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

 

 
css,Html,tooltip,文字提示

 

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

 

 
css,Html,tooltip,文字提示 

 

不多逼逼,讓我們來定幾個(gè)期望 不用javascript腳本, 純css 實(shí)現(xiàn) 不用添加新元素**(用after、before偽元素)** 不用類名匹配,直接用屬性選擇器**([attr])** 支持默認(rèn)樣式**(標(biāo)簽沒定義主題、位置的時(shí)候)** 指令式**(直接在標(biāo)簽定義即可,接下來交給css匹配)** 實(shí)現(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 — 氣泡相對(duì)于父元素的 位置 (top / top-left/ top-right / right / right-top/ right-bottom...),默認(rèn)top;
     

先寫幾個(gè)按鈕

樣式借鑒element-ui

 

 
css,Html,tooltip,文字提示

 

<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核心代碼邏輯實(shí)現(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)移入之后便有效果

 

 
css,Html,tooltip,文字提示

 

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

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

目前效果如下

 

 
css,Html,tooltip,文字提示 

 

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

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

/* 氣泡默認(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)主題(黑底) */}

目前效果如下

 

 
css,Html,tooltip,文字提示 

 

定制氣泡、三角形主題色

定義好各兩種主題

$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; /* 暫時(shí)跟dark一樣 */}

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

/* 氣泡位置 *//*----上----*/.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 屬性 / 為空的時(shí)候,默認(rèn)繼承top位置

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

目前效果如下

 

 
css,Html,tooltip,文字提示

 

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

 

 
css,Html,tooltip,文字提示 加個(gè)動(dòng)畫

 

分四個(gè)方向,上下左右,四個(gè)動(dòng)畫

@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í)行哪個(gè)動(dòng)畫,用**[attr^=]**選擇,如 上左、上右也能匹配到

/* 設(shè)置動(dòng)畫 */@each $placement in top, right,bottom,left {  &[placement^="#{$placement}"] {    &::after,    &::before {      animation: anime-#{$placement} 300ms ease-out forwards;    }  }}

最終效果如下

 

 
css,Html,tooltip,文字提示

 

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

總結(jié)

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


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到HTML教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 绥滨县| 深水埗区| 临湘市| 天柱县| 彰化市| 大冶市| 黔西| 泗阳县| 佛坪县| 射阳县| 安福县| 婺源县| 康乐县| 宁阳县| 洛阳市| 湘潭县| 高邮市| 同江市| 岳阳县| 佳木斯市| 凤台县| 云梦县| 松桃| 江华| 博罗县| 堆龙德庆县| 宜兴市| 库尔勒市| 安吉县| 科技| 谢通门县| 德格县| 葵青区| 昌吉市| 靖江市| 鹤岗市| 昆山市| 漳州市| 郸城县| 嵩明县| 台北市|