成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

CSS3 巧妙實(shí)現(xiàn)聊天氣泡

bang590 / 1768人閱讀

摘要:想必大家都知道,這里不贅述,聊一聊其他實(shí)現(xiàn)方法。這里的三角形部分可以使用正方形代替,實(shí)現(xiàn)同樣效果,方法就是旋轉(zhuǎn)小正方形使其一部分露在外面。

前一陣子敢玩的 Mobile 頁(yè)改版完成了,就之前的頁(yè)面風(fēng)格更加扁平化,從暗色系為主背景轉(zhuǎn)到亮色背景,去掉更多的陰影,給用戶簡(jiǎn)約的體驗(yàn)風(fēng)格,哈哈我不是設(shè)計(jì)師不過多評(píng)價(jià)啦。感興趣的朋友可以直接去 idarex移動(dòng)端主頁(yè)。

這次改版的所有 style 都是 orange 寫的,感觸頗多,分期分享給大家

下面說正題,說好的聊天氣泡呢?

傳統(tǒng)的聊天氣泡

什么又是傳統(tǒng)的聊天氣泡,直接上圖

代碼如下

實(shí)現(xiàn)方式大家早有耳聞,圓角矩形和三角形嘛,三角形原理就是 border 可以設(shè)置為透明,可以復(fù)制上例中的代碼修改 border-color 屬性摸索三角形的實(shí)現(xiàn)。

注:IE8 更早版本對(duì) border 的 transparent 支持不是很好。大家可以無視低版本缺陷,因?yàn)榇蟛糠譃g覽器都顯示正常,非要兼容的話把 transparent 屬性設(shè)置為主背景色而不是氣泡背景色(前提是背景為純色)。

想必大家都知道,這里不贅述,聊一聊其他實(shí)現(xiàn)方法。

這里的三角形部分可以使用正方形代替,實(shí)現(xiàn)同樣效果,方法就是旋轉(zhuǎn)小正方形使其一部分露在外面。代碼如下

.comment {
  position: relative;
  width: 150px;
  height: 35px;
  background: #f8ac09;
  border-radius: 5px;
  margin: 30px auto 0;
}

.comment:after {
  content: "";
  position:absolute;
  top: 10px;
  right: -4px;
  width: 8px;
  height: 8px;
  transform: rotate(45deg);
  background-color: #f8ac09;
}

缺點(diǎn)是小三角只能是直角三角形,當(dāng)然也可以通過變換得到菱形再進(jìn)行拼接,變換多了感覺沒有第一種方式直接,瀏覽器兼容 transform(2D) 屬性如下

總體還不錯(cuò),幾種方法都能放心使用,不存在大的兼容問題。

現(xiàn)實(shí)案例

這里的設(shè)計(jì)稿多了一個(gè)邊框,直接上設(shè)計(jì)稿

?? 想一想怎么處理,我們回顧上文

第一種方式本身就是 border 透明,怎么再給它設(shè)置 border 是個(gè)問題,暫且先不考慮。

第二種方式如果使用小正方形旋轉(zhuǎn),層級(jí)疊加是個(gè)問題,因?yàn)樵O(shè)計(jì)稿中的氣泡背景為 rgba(247, 188, 10, 0.03) 先看下實(shí)現(xiàn)代碼

.comment {
  width: 150px;
  height: 35px;
  position:relative;
  margin: 30px auto 0;
  background-color: rgba(247, 188, 10, 0.03);
  border: 1px solid rgba(252, 185, 8, 0.35);
  border-radius: 5px;
}

.comment:after {
  content: "";
  width: 8px;
  height: 8px;
  position: absolute;
  top: 10px;
  right: -4px;
  transform: rotate(45deg);
  background-color: rgba(247, 188, 10, 0.03);
  border: 1px solid rgba(252, 185, 8, 0.35);
}

效果如下

上面的思路有問題,因?yàn)樾≌叫闻c氣泡的一部分會(huì)重合,半透明背景的部分總會(huì)出現(xiàn)問題,有人說了偷個(gè)懶總可以吧,把透明后的背景色吸取出來然后再進(jìn)行疊加(因?yàn)榇蠹易⒁獾皆O(shè)計(jì)稿的整體背景是純色)

按著這個(gè)思路去實(shí)現(xiàn),那么問題又來了。具體兩個(gè)問題如下。

1.如果小正方形疊加在上,那么小正方形左半部分的邊框就會(huì)顯示

.comment {
  width: 150px;
  height: 35px;
  position: relative;
  margin: 30px auto 0;
  background-color: #faf8f3;
  border: 1px solid #fbe2a0;
  border-radius: 5px;
}

.comment:after {
  content: "";
  width: 8px;
  height: 8px;
  position:absolute;
  top: 10px;
  right: -4px;
  transform: rotate(45deg);
  background-color: #faf8f3;
  border: 1px solid #fbe2a0;
}

效果如下,比較之前的圖片圓角矩形的右邊確實(shí)遮住了,但小正方形左邊的邊框顯示出來了

處理方式呢,可以這樣。

.comment:after {
  content: "";
  width: 8px;
  height: 8px;
  position: absolute;
  top: 10px;
  right: -5px;
  transform: rotate(45deg);
  background-color: #faf8f3;
  border: 1px #fbe2a0;
  border-style: solid solid none none;
}

我們發(fā)現(xiàn)問題解決了。效果如下

設(shè)計(jì)稿是有 padding 的,親測(cè)本案例中可行,但是本著認(rèn)真的原則 padding-right 如果過小,會(huì)出現(xiàn)什么問題呢?

我們向 div 中加文字。

Hello,orange.Welcome to FrontEnd World!

效果如下

我們發(fā)現(xiàn)字母 o 的右下角被小正方形左側(cè)覆蓋了,當(dāng)然可以通過 z-index 屬性 hack。

2.如果小正方形在圓角矩形下,那么圓角矩形的右邊框就會(huì)完整顯示,大家自行腦補(bǔ),此方案不合理,不過多解釋。

以上的方法缺點(diǎn)也都很明顯,那怎么做才能更嚴(yán)謹(jǐn),能根據(jù)需求的變化不大傷筋骨呢?

我們還用三角形的方案! what? 不是說三角形的方案不可行了嘛 ?

一個(gè)三角形是不可行那兩個(gè)呢,我們有請(qǐng) after 的兄弟 before 出場(chǎng)。項(xiàng)目的真實(shí)代碼如下

.reply {
  position: relative;
  margin: 0.672rem 0 0.096rem 0;
  padding: 0.408rem 0.816rem;

  border: 1px solid rgba(#fcb908, 0.35);
  border-radius: 0.2rem;
  background-color: rgba(#f7bc0a, 0.03);

  &:after {
    content: "";
    width: 0px;
    height: 0px;
    border-color:  transparent transparent #faf8f3 transparent ;
    border-style: solid;
    border-width: 6px;
    position: absolute;
    top: -11px;
    border-radius: 3px;
    left: 18px;
    right: auto;
  }

  &:before {
    content: "";
    width: 0px;
    height: 0px;
    border-color: transparent transparent rgba(#fcb908, 0.35) transparent;
    border-style: solid;
    border-width: 7px;
    position: absolute;
    top: -14px;
    border-radius: 3px;
    left: 17px;
    right: auto;
  }
}
注:這段代碼用的是 SASS 進(jìn)行預(yù)編譯,如果從頭仔細(xì)看到這里的話不難理解,兩個(gè)三角形疊加,大三角形顏色是邊框的顏色,小三角形是內(nèi)部背景色,小三角形絕對(duì)定位時(shí)向下移 3px 把圓角矩形的一部分上邊框遮擋,這樣小三角下部也有溢出,具體在兩像素之內(nèi),實(shí)際上不存在遮擋文本問題。
總結(jié)

實(shí)際問題解決的方法很多,就看大家怎么去思考,這個(gè)方案也不是最滿意的方案,因?yàn)槎嗔艘粋€(gè)偽元素,主要還是設(shè)計(jì)思想的多樣性,總之 css 很靈活。

有人不禁會(huì)問,這里設(shè)計(jì)稿給的是向上的箭頭,為什么例子里卻都是向右的,這里向右的都是我寫的 demo ,理解原理的話,改變個(gè)位置方向都是大同小異。

最后,讀本文有收獲的或者有更好想法的朋友,歡迎下方留言交流。

文章出自 orange 的 個(gè)人博客 http://orangexc.xyz/

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/111649.html

相關(guān)文章

  • CSS3 聊天氣泡框以及 inherit、currentColor 關(guān)鍵字

    摘要:效果如上圖所示,主要用到的偽類,以及圓角邊框?qū)傩?。的屬性的使用然后通過定位到合適的位置。實(shí)現(xiàn)氣泡框結(jié)果也很簡(jiǎn)單,就一個(gè)。的關(guān)鍵字與之類似的還有一個(gè)新的顏色屬性。實(shí)際上,這是中有史以來第一個(gè)變量,雖然功能很有限,但它真的是個(gè)變量。 showImg(https://segmentfault.com/img/remote/1460000010869212);效果如上圖所示,主要用到CSS3的...

    kel 評(píng)論0 收藏0
  • CSS3 聊天氣泡框以及 inherit、currentColor 關(guān)鍵字

    摘要:效果如上圖所示,主要用到的偽類,以及圓角邊框?qū)傩浴5膶傩缘氖褂萌缓笸ㄟ^定位到合適的位置。實(shí)現(xiàn)氣泡框結(jié)果也很簡(jiǎn)單,就一個(gè)。的關(guān)鍵字與之類似的還有一個(gè)新的顏色屬性。實(shí)際上,這是中有史以來第一個(gè)變量,雖然功能很有限,但它真的是個(gè)變量。 showImg(https://segmentfault.com/img/remote/1460000010869212);效果如上圖所示,主要用到CSS3的...

    _ipo 評(píng)論0 收藏0
  • SegmentFault 技術(shù)周刊 Vol.38 - 神奇的 CSS

    摘要:層疊即表示允許以多種方式來描述樣式,一個(gè)元素可以被渲染呈現(xiàn)出多種樣式??梢宰寣傩缘淖兓^程持續(xù)一段時(shí)間,而不是立即生效。比如,將元素的顏色從白色改為黑色,通常這個(gè)改變是立即生效的,使用后,將按一個(gè)曲線速率變化。 showImg(https://segmentfault.com/img/bVZwyL?w=900&h=385); CSS 的全稱是 Cascading Style Sheet...

    elliott_hu 評(píng)論0 收藏0
  • 怎么實(shí)現(xiàn)微信聊天時(shí)的氣泡圖(一)

    摘要:下面是得到小三角的三個(gè)關(guān)鍵點(diǎn),在這里我默認(rèn)小三角是等邊三角形了,給出三角形頂點(diǎn)坐標(biāo)進(jìn)行了,其他兩點(diǎn)的坐標(biāo)都在邊界上,截圖里的兩點(diǎn)。下面就拼接憑借函數(shù)的參數(shù)了完整代碼看這里參考 首先,微信聊天的時(shí)候氣泡圖是什么樣呢?上圖,showImg(https://segmentfault.com/img/bVtQDZ);,要實(shí)現(xiàn)這種氣泡圖,要怎么做?主要的就是實(shí)現(xiàn)那個(gè)小三角嗎?首先想到的肯定是使用...

    whinc 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<