婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

熱門標簽:地圖標注沿海城市房價 智能語音電銷機器人客戶端 西安金倫外呼系統 威海語音外呼系統平臺 地圖標注員工作內容 中國地圖標注城市的 通遼地圖標注app 江西ai電銷機器人如何 高德地圖標注廁所

 

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

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

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

 

不多逼逼,讓我們來定幾個期望 不用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

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

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

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

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

/* 三角形默認樣式 */
&::before {
  display: block;
  content: '';
}

目前效果如下

 

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

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

/* 氣泡默認樣式 */
&::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; /* 繼承默認主題(黑底) */
}

目前效果如下

 

定制氣泡、三角形主題色

定義好各兩種主題

$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;
  }
}

目前效果如下

讓我們把文字放長,把氣泡、三角形的默認樣式加上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%;
  }
}

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

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

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

最終效果如下

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

總結

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

標簽:河池 北海 青海 阜陽 營口 晉中 眉山 崇左

巨人網絡通訊聲明:本文標題《純css實現(無腳本)Html指令式tooltip文字提示效果》,本文關鍵詞  純,css,實現,無,腳本,Html,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《純css實現(無腳本)Html指令式tooltip文字提示效果》相關的同類信息!
  • 本頁收集關于純css實現(無腳本)Html指令式tooltip文字提示效果的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91网站最新网址| 日韩专区在线视频| 国产欧美一区二区精品性色| 欧美日韩综合色| 欧美中文字幕久久| 欧美理论在线播放| 在线电影欧美成精品| 欧美日韩视频不卡| 日韩欧美亚洲国产另类| 日韩精品一区二区三区在线观看| 欧美一区二区三区免费在线看| 4438亚洲最大| wwwwxxxxx欧美| 国产日产欧美一区二区视频| 国产精品嫩草影院av蜜臀| 中文字幕一区二区三区色视频| 亚洲国产成人私人影院tom| 国产欧美一区在线| 一区二区三区不卡视频在线观看| 一二三四区精品视频| 秋霞国产午夜精品免费视频| 久久狠狠亚洲综合| 成人开心网精品视频| 色av一区二区| 精品欧美黑人一区二区三区| 中文字幕日本不卡| 天堂一区二区在线| 国产精品综合网| av在线一区二区三区| 欧美福利视频一区| 国产精品私房写真福利视频| 亚洲成人自拍网| 国产精品一区三区| 欧美性感一区二区三区| 26uuu另类欧美| 亚洲精品日产精品乱码不卡| 久色婷婷小香蕉久久| aaa亚洲精品| 日韩精品一区二区三区swag | 欧美亚洲综合网| 国产精品久久久爽爽爽麻豆色哟哟 | 成人精品免费视频| 欧洲精品中文字幕| 久久综合久色欧美综合狠狠| 亚洲黄色性网站| 国产成人免费xxxxxxxx| 欧美亚洲一区二区在线| 国产色综合久久| 亚洲第一成人在线| 9l国产精品久久久久麻豆| 69成人精品免费视频| 亚洲欧美韩国综合色| 国产在线精品一区二区夜色| 欧美日韩成人综合在线一区二区| 亚洲欧洲精品一区二区三区不卡| 美脚の诱脚舐め脚责91| 欧美精品第1页| 亚洲一区二区三区免费视频| a亚洲天堂av| 国产精品久久久久久一区二区三区| 亚洲超碰97人人做人人爱| 99精品国产视频| 国产三级久久久| 久国产精品韩国三级视频| 欧美一区二区精品在线| 天天综合日日夜夜精品| 欧美性色综合网| 亚洲国产日韩一级| 日本高清成人免费播放| 亚洲六月丁香色婷婷综合久久| 国产成a人无v码亚洲福利| 久久亚洲综合色一区二区三区| 天堂va蜜桃一区二区三区| 欧美综合亚洲图片综合区| 国产精品久久久久久久蜜臀| 国产精品18久久久| 国产人伦精品一区二区| 国产成人aaa| 国产精品国产自产拍高清av| 波多野结衣中文一区| 亚洲免费观看在线视频| 91在线免费看| 亚洲午夜精品久久久久久久久| 欧美性极品少妇| 亚洲444eee在线观看| 日韩免费看的电影| 国产美女一区二区| 亚洲欧洲日产国码二区| 欧美性videosxxxxx| 石原莉奈一区二区三区在线观看| 日韩欧美国产午夜精品| 国产精品99久久久久久久vr| 亚洲视频中文字幕| 中文字幕亚洲在| 在线观看日韩精品| 另类小说欧美激情| 国产人成一区二区三区影院| 色婷婷精品大在线视频| 日韩和欧美一区二区| 欧美不卡一区二区三区| 国产91在线|亚洲| 亚洲永久免费视频| 日韩免费福利电影在线观看| 不卡欧美aaaaa| 午夜成人免费电影| 国产网站一区二区三区| 欧洲一区二区三区免费视频| 韩国精品免费视频| 一区二区三区免费观看| 日韩精品一区二区三区视频播放| 国产成a人亚洲| 日本午夜一区二区| 国产精品超碰97尤物18| 日韩亚洲欧美在线| 91极品视觉盛宴| 国产精选一区二区三区| 无吗不卡中文字幕| 亚洲国产精品成人综合色在线婷婷| 欧美性大战xxxxx久久久| 国产成人在线网站| 美女视频网站久久| 一区二区三区四区在线播放| 久久中文娱乐网| 欧美一区二区三区四区久久| 色噜噜狠狠色综合欧洲selulu| 国产专区欧美精品| 丝袜美腿一区二区三区| 中文字幕一区二区日韩精品绯色| 91精品国产91久久久久久最新毛片 | 麻豆一区二区99久久久久| 亚洲免费伊人电影| 中文字幕 久热精品 视频在线 | 国产成人精品aa毛片| 丝袜亚洲另类欧美综合| 一卡二卡三卡日韩欧美| 综合色中文字幕| 国产色一区二区| 国产午夜三级一区二区三| 91精品国产91久久综合桃花| 欧美四级电影网| 色激情天天射综合网| 色综合久久中文综合久久牛| 成人精品一区二区三区中文字幕| 国产精品亚洲成人| 国产精品一区在线| 顶级嫩模精品视频在线看| 国产在线一区二区| 国产精品性做久久久久久| 国产成人免费网站| 激情文学综合网| 国产成人免费视频一区| 东方欧美亚洲色图在线| eeuss鲁一区二区三区| av一区二区不卡| 91免费在线看| 在线国产电影不卡| 欧美亚洲国产怡红院影院| 一本久道中文字幕精品亚洲嫩| 色婷婷av一区二区三区软件 | 亚洲国产精品人人做人人爽| 亚洲人成人一区二区在线观看| 亚洲一区在线看| 麻豆91在线播放免费| 成人黄色在线视频| 播五月开心婷婷综合| 91一区二区三区在线观看| 欧美午夜不卡视频| 中文字幕av一区二区三区高| 欧美国产一区二区在线观看| 亚洲欧美中日韩| 亚洲国产精品精华液2区45| 亚洲大尺度视频在线观看| 亚洲在线视频网站| 日韩理论片中文av| 亚洲色图欧美在线| 亚洲精品中文字幕乱码三区| www.性欧美| 欧美亚洲愉拍一区二区| 91在线看国产| 91麻豆精品国产综合久久久久久| 美女视频黄 久久| 亚洲精品国产视频| 欧美精品亚洲二区| 久久婷婷国产综合精品青草| 亚洲区小说区图片区qvod| 亚洲欧美色综合| 日韩在线a电影| 成人免费毛片片v| 欧美中文一区二区三区| 91美女在线看| 国产亚洲va综合人人澡精品| 国产伦精品一区二区三区视频青涩| 亚洲日本一区二区| 久久蜜桃香蕉精品一区二区三区| 国产精品欧美久久久久一区二区| 亚洲欧美在线另类| 极品美女销魂一区二区三区免费 | 成人欧美一区二区三区小说| 天天av天天翘天天综合网色鬼国产| 国产精品99久久久|