css 11種方法實現(xiàn)一個tips帶有描邊的小箭頭

我們在網(wǎng)頁開發(fā)中實現(xiàn)一個tips時會有一個小箭頭,實現(xiàn)這種方法的文章網(wǎng)上已經(jīng)泛濫了,但有時實現(xiàn)這個小箭頭不止只有單純的三角它還有描邊,今天我們就借那些現(xiàn)有的文章在深入一點來說說如何給tips小箭頭描邊,本章不涉及svg/canvas,沒必要因為我講的是css。
主體樣式:
<div class="dui-tips"><a href="http://www.w3cbest.com">w3cbest我是一個tips</a></div> .dui-tips{ position: relative; padding: 10px; text-align: center; border: 1px solid #f60; border-radius: 5px; background-color: #fff; }
第一種border描邊雙層覆蓋:
就是大家常用的border,實現(xiàn)原理就是給其中一條邊設(shè)置顏色寬度及樣式,我這里使用了兩個偽類進行折疊,將一個白色的覆蓋在有顏色的偽類上面,再偏移1px來模擬實現(xiàn)1px的描邊效果,代碼如下:
.dui-tips { &:before, &:after { position: absolute; left: 50%; display: table; width: 0; height: 0; content: ''; transform: translate(-50%, 0); border-width: 10px 10px 0 10px; border-style: solid; } &:before { z-index: 0; bottom: -10px; border-color: #f60 transparent transparent transparent; } &:after { z-index: 1; bottom: -8px; border-color: #fff transparent transparent transparent; } }
第二種border描邊結(jié)合濾鏡drop-shadow屬性:
第二種是第一種的延伸,使用濾鏡filter的drop-shadow描邊來實現(xiàn),box-shadow和drop-shadow實現(xiàn)不規(guī)則投影
.dui-tips { &:after { position: absolute; left: 50%; display: table; width: 0; height: 0; content: ''; transform: translate(-50%, 0); border-width: 10px 10px 0 10px; border-style: solid; bottom: -9px; border-color: #fff transparent transparent transparent; filter: drop-shadow(0px 2px 0px #f60); } }
第三種通過特殊符號或字體雙層覆蓋
第三種方法和第一種類似,通過兩層顏色疊加在有層級的偏移來實現(xiàn)
.dui-tips { &:before, &:after { font-size: 24px; line-height: 18px; position: absolute; left: 50%; display: table; content: '◆'; transform: translate(-50%, 0); text-align: center; } &:before { z-index: 0; bottom: -10px; color: #f60; } &:after { z-index: 1; bottom: -8px; color: #fff; } }
第四種通過text-shadow實現(xiàn)
這種放發(fā)通過給文子設(shè)置1px的陰影來顯描邊效果
.dui-tips { &:after { font-size: 24px; line-height: 18px; position: absolute; left: 50%; display: table; content: '◆'; transform: translate(-50%, 0); text-align: center; z-index: 1; bottom: -8px; color: #fff; text-shadow: 0 2px 0 #f60; } }
第五種 background雙層覆蓋
這種方式設(shè)置兩個寬度和高度分別為10px的方塊背景,再給兩層背景分別設(shè)置不同的顏色,再通過兩層背景顏色疊加,經(jīng)過層級偏移再有transform的rotate屬性旋轉(zhuǎn)角度,來實現(xiàn)箭頭的朝向。
.dui-tips { &:before, &:after { position: absolute; left: 50%; display: table; width: 10px; height: 10px; content: ''; margin-left: -5px; transform: rotate(-45deg); } &:before { z-index: 0; bottom: -6px; background-color: #f60; } &:after { z-index: 1; bottom: -5px; background-color: #fff; } }
第六種background和border背景描邊旋轉(zhuǎn)
此方法就是設(shè)置一個寬度和高度分別為10px的方塊背景,然后背景相鄰的兩條邊描邊再有transform的rotate屬性旋轉(zhuǎn)角度,來實現(xiàn)箭頭的朝向。
.dui-tips { &:after { position: absolute; left: 50%; display: table; width: 10px; height: 10px; margin-left: -5px; content: ''; transform: rotate(-45deg); z-index: 1; bottom: -6px; border-bottom: 1px solid #f60; border-left: 1px solid #f60; background-color: #fff; } }
第七種background和box-shadow
.dui-tips { &:after { position: absolute; left: 50%; display: table; width: 10px; height: 10px; content: ''; margin-left: -5px; transform: rotate(-45deg); z-index: 1; bottom: -5px; background-color: #fff; box-shadow: -1px 1px 0 #f60; } }
第八種linear-gradient
.dui-tips{ &:before, &:after{ position: absolute; left: 50%; display: table; width: 10px; height: 10px; content: ''; margin-left: -5px; transform: rotate(-135deg); } &:before { z-index: 0; bottom: -6px; background: linear-gradient(-45deg, transparent 7px, #f60 0); } &:after { z-index: 1; bottom: -5px; background: linear-gradient(-45deg, transparent 7px, #fff 0); } }
第九種linear-gradient和box-shadow
.dui-tips{ &:after{ position: absolute; left: 50%; display: table; width: 10px; height: 10px; content: ''; margin-left: -5px; transform: rotate(-135deg); z-index: 1; bottom: -5px; background: linear-gradient(-45deg, transparent 7px, #fff 0); box-shadow: -1px -1px 0 #f60 } }
第十種linear-gradient和border
.dui-tips{ &:after{ position: absolute; left: 50%; display: table; width: 10px; height: 10px; content: ''; margin-left: -5px; transform: rotate(-135deg); z-index: 1; bottom: -6px; background: linear-gradient(-45deg, transparent 7px, #fff 0); border-top: 1px solid #f60; border-left: 1px solid #f60; } }
第十一種ouline
.dui-tips { &:before, &:after { position: absolute; left: 50%; display: table; width: 0; height: 0; content: ''; transform: rotate(45deg); outline-style: solid; outline-width: 5px; } &:before { z-index: 0; bottom: -1px; outline-color: #f60; } &:after { z-index: 1; bottom: 0; outline-color: #fff; } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
CSS實現(xiàn)鼠標(biāo)懸停svg圖標(biāo)描邊效果
這篇文章主要介紹了CSS實現(xiàn)鼠標(biāo)懸停svg圖標(biāo)描邊效果,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-30