border-width实现博客园回复效果
一、发现
前端渣哥逛博客园,经常看到博文评论有这种如下这种效果:
开始还以为是用图片实现的,额...。像博客园这种访问量大的网站,能用js/css实现的就不会用图片代替,果然,仔细一看,两个span就能实现这个效果了。
二、实现
看到不会或者不清楚的,总想探个究竟,并把知识变成自己的。接下来就花点时间,实现这种效果。
2.1 以span 设置 border-width:20px; 为例,这样相当于一个 40*40 的正方形(上下(20*2)和左右(20*2)),然后平分成4份,怎么平分呢,上下左右4个全等三角型就是了。既然这样,我们就可以轻松实现以下效果了:
2.2 有了上面的做法,我们同样可以再用一个span,实现如下效果:
这样,把浅蓝色部分换成白色,就可以实现遮挡,再通过绝对定位,就可以实现我们想要的效果了。
2.3 完整代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 | <! 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,以此小记。代码不自己敲就不是你的,有空逛逛园子总会有收获。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构