一、發現
前端渣哥逛博客園,經常看到博文評論有這種如下這種效果:
開始還以為是用圖片實現的,額...。像博客園這種訪問量大的網站,能用js/css實現的就不會用圖片代替,果然,仔細一看,兩個span就能實現這個效果了。
二、實現
看到不會或者不清楚的,總想探個究竟,並把知識變成自己的。接下來就花點時間,實現這種效果。
2.1 以span 設置 border-width:20px; 為例,這樣相當於一個 40*40 的正方形(上下(20*2)和左右(20*2)),然后平分成4份,怎么平分呢,上下左右4個全等三角型就是了。既然這樣,我們就可以輕松實現以下效果了:
2.2 有了上面的做法,我們同樣可以再用一個span,實現如下效果:
這樣,把淺藍色部分換成白色,就可以實現遮擋,再通過絕對定位,就可以實現我們想要的效果了。
2.3 完整代碼
<!DOCTYPE> <html> <head> <title>css實現博客園回復效果</title> <style type="text/css"> *{margin:0;padding:0;} #reply{ width:600px; margin:0 auto; } .reply_item{ padding:10px 20px; border-bottom:1px solid #EDD98B; } .reply_img{ float:left; } .reply_img a{ float:left; margin-top:20px; text-decoration:none; color:#fff; } .reply_img img{ width:60px; height:60px; border-radius:40px; } .reply_content{ margin-left:110px; background:#beceeb; padding:30px 20px; border-radius:18px; position:relative; } .dot{ border-style:solid; border-width:20px; border-color:#fff #beceeb #beceeb #fff; position:absolute; left:-40px; top:40px; } .top{ border-style:solid; border-width:10px 20px; border-color:transparent #fff #fff transparent; position:absolute; left:-40px; top:60px; } </style> </head> <body> <div id="reply"> <div class="reply_item"> <div class="reply_img"> <a href="http://www.cnblogs.com"> <img src="1.jpg" alt="用戶頭像" /> </a> </div> <div class="reply_content"> 好文,要攢 <div class="dot"></div> <div class="top"></div> </div> </div> </div> </body> </html>
2.4 效果圖:
三、總結
一個簡單的demo,以此小記。代碼不自己敲就不是你的,有空逛逛園子總會有收獲。