亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

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

2024-08-26 00:21:33
字體:
來源:轉載
供稿:網友
css,Html,tooltip,文字提示 

 

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

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

 

 
css,Html,tooltip,文字提示

 

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

 

 
css,Html,tooltip,文字提示 

 

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

指令式聲明

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

先寫幾個按鈕

樣式借鑒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核心代碼邏輯實現

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

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

現在鼠標移入之后便有效果

 

 
css,Html,tooltip,文字提示

 

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

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

目前效果如下

 

 
css,Html,tooltip,文字提示 

 

設置氣泡、三角形的默認樣式

核心顯示當然是設置絕對定位了

/* 氣泡默認樣式 */&::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; /* 繼承默認主題(黑底白字) */ }/* 三角形默認樣式 */&::before {  display: block;  content: '';  position: absolute;  border: 5px solid transparent;  z-index: 100;  @extend .triangle-theme-dark; /* 繼承默認主題(黑底) */}

目前效果如下

 

 
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; /* 暫時跟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;}

捕捉位置、主題

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

匹配氣泡、三角形主題

&[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};    }  }}

標簽不存在placement 屬性 / 為空的時候,默認繼承top位置

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

目前效果如下

 

 
css,Html,tooltip,文字提示

 

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

 

 
css,Html,tooltip,文字提示 加個動畫

 

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

@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%;  }}

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

/* 設置動畫 */@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 …

總結

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产精品电影| 九九精品视频在线观看| 亚洲精品成人久久久| 尤物九九久久国产精品的分类| 中文字幕亚洲一区| 国产成人精品久久亚洲高清不卡| 亚洲乱码国产乱码精品精天堂| 欧美日韩精品在线播放| 日韩福利视频在线观看| 日韩精品视频在线免费观看| 欧美国产日产韩国视频| 911国产网站尤物在线观看| 欧美电影免费观看高清| 日本精品一区二区三区在线| 国产精品福利无圣光在线一区| 亚洲欧美日韩国产精品| 欧美日韩国产成人高清视频| 懂色av中文一区二区三区天美| 国产成人精品在线| 亚洲电影免费观看高清| 国产999精品| 一区二区三区亚洲| 久久久久久中文字幕| 青青久久aⅴ北条麻妃| 国产精品视频最多的网站| 久久久久久有精品国产| 欧美激情aaaa| 日韩亚洲综合在线| 久久久久久12| 亚洲欧美日韩第一区| 精品国产一区二区三区久久久狼| 欧美另类在线观看| 北条麻妃99精品青青久久| 国模私拍一区二区三区| 欧美黑人xxx| 欧美劲爆第一页| 国产精品美女久久久免费| 国产91精品不卡视频| 国产福利视频一区二区| 亚洲毛片在线观看.| 欧美专区福利在线| 91最新在线免费观看| 成人在线小视频| 亚洲国产精品999| 亚洲电影av在线| 久久91亚洲精品中文字幕奶水| 日韩精品在线免费| 久久久国产精品一区| 国产日韩欧美在线| 久久影视电视剧免费网站清宫辞电视| 国产精品成人一区| 中文字幕亚洲专区| 国外成人在线视频| 亚洲黄色成人网| 欧美成人午夜剧场免费观看| 国产精品视频午夜| 在线日韩欧美视频| 亚洲美女在线观看| 午夜精品久久久久久久99黑人| 国产一区二区三区高清在线观看| 成人黄色在线观看| 久久久中文字幕| 成人网页在线免费观看| 久久91亚洲人成电影网站| 欧美激情区在线播放| 国产视频精品一区二区三区| 日韩在线中文视频| 欧美午夜激情小视频| 91中文精品字幕在线视频| 色av中文字幕一区| 亚洲激情国产精品| 日韩视频永久免费观看| 成人免费网视频| 亚洲精品视频免费| 亚洲精品视频在线播放| 欧美日韩国产综合视频在线观看中文| 在线精品播放av| 亚洲电影免费观看高清完整版在线| 亚洲国产中文字幕久久网| 欧美性猛交视频| 欧美第一黄色网| 高清欧美性猛交xxxx| 国产精品美女久久久久久免费| 国产精品一区二区久久久| 国产精品色婷婷视频| 久久精品成人欧美大片古装| 亚洲第一福利视频| 日韩av日韩在线观看| 国产精品久久久一区| 精品久久久久久久久国产字幕| 国产在线一区二区三区| 国产精品久久久久影院日本| 国产精品网站大全| 国产精品极品美女粉嫩高清在线| 欧美成人h版在线观看| 美女国内精品自产拍在线播放| 欧美久久久精品| 国产精品18久久久久久麻辣| 中文字幕精品—区二区| 亚洲日本成人女熟在线观看| 91在线直播亚洲| 日韩一级裸体免费视频| 中文字幕欧美在线| 欧美国产日韩一区| 欧美富婆性猛交| 国产免费一区视频观看免费| 亚洲aaa激情| 亚洲男人天堂2024| 欧美日韩999| 91久久久久久久久久久| 国产一区二区三区久久精品| 国产精品久久久久久久久久| 欧美日韩国产中文精品字幕自在自线| 久久久精品视频成人| 川上优av一区二区线观看| 爽爽爽爽爽爽爽成人免费观看| 欧美性极品xxxx做受| 久久精品中文字幕免费mv| 91在线精品播放| 在线视频亚洲欧美| 韩国欧美亚洲国产| 欧美中文字幕在线播放| 精品国产一区二区三区久久久| 最好看的2019年中文视频| 国产精品一区二区三区毛片淫片| 国外日韩电影在线观看| 日本欧美爱爱爱| 欧美激情免费在线| 97超级碰碰碰| 欧美性猛交xxxx乱大交3| 亚洲国产精品久久久久| 精品视频在线播放免| 最近2019中文字幕一页二页| 亚洲一区二区三| 精品久久久久久国产| 亚洲精品电影在线| 日韩精品在线观看一区二区| 国产精品免费视频xxxx| 国产成人短视频| 亚洲国产天堂网精品网站| 夜夜躁日日躁狠狠久久88av| 国外成人性视频| 日韩电影在线观看中文字幕| 欧美在线播放视频| 久久九九免费视频| 91久久久久久| 色综合久久88色综合天天看泰| 欧美日韩精品二区| 欧美大片va欧美在线播放| 国产精品91久久久久久| 亚洲欧美中文日韩在线v日本| 成年无码av片在线| 精品久久久久久国产| 国产精品www网站| 性色av一区二区三区在线观看| 伊人久久免费视频| 精品国内自产拍在线观看| 国产极品精品在线观看| 国产精品久久久久久搜索| 亚洲色图50p| 国产小视频91| 久久久国产91| 91超碰caoporn97人人| 成人a视频在线观看|