css实现小三角(原理) - 林七七
效果图如图1所示:(简单示范,有点丑,莫介意)
PS:兼容IE,FF , chrome ,360安全浏览器



先讲下原理吧,如图2所示:


<span style="font-size: 15px;"><span style="color: #800000;">div</span>{<span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 0px</span>;<span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 0px</span>;<span style="color: #ff0000;"> border-width</span>:<span style="color: #0000ff;"> 20px</span>;<span style="color: #ff0000;"> border-style</span>:<span style="color: #0000ff;"> solid</span>;<span style="color: #ff0000;"> border-color</span>:<span style="color: #0000ff;"> lightgreen pink yellow lightblue</span>; }</span>
登录后复制
解释:当div的宽高为0时,设border的宽度并设颜色,会发现div像是被分割为4个小三角形,
因此当我们要其中一个小三角时,只需要将其它三个隐藏即可(方法:把那三条边颜色设为transparent即可)。
上三角:(图3)


对应的CSS代码:
<span style="font-size: 15px;"><span style="color: #800000;">#triangle</span>{<span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 0px</span>;<span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 0px</span>;<span style="color: #ff0000;"> border-width</span>:<span style="color: #0000ff;"> 20px</span>;<span style="color: #ff0000;"> border-style</span>:<span style="color: #0000ff;"> solid</span>;<span style="color: #ff0000;"> border-color</span>:<span style="color: #0000ff;"> transparent transparent yellow transparent</span>; }</span>
登录后复制
为了让它尽可能适应各种浏览器,我们多添加几行代码(主要是解决IE的兼容问题):
<span style="font-size: 15px;"><span style="color: #008080;"> 1</span> <span style="color: #800000;">#triangle</span>{ <span style="color: #008080;"> 2</span> <span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 0px</span>; <span style="color: #008080;"> 3</span> <span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 0px</span>; <strong><span style="color: #008080;"> 4</span> <span style="color: #ff0000;"> *width</span>:<span style="color: #0000ff;"> 40px</span>; <span style="color: #008080;"> 5</span> <span style="color: #ff0000;"> *height</span>:<span style="color: #0000ff;"> 40px</span>; <span style="color: #008080;"> 6</span> <span style="color: #ff0000;"> font-size</span>:<span style="color: #0000ff;"> 0</span>; <span style="color: #008080;"> 7</span> <span style="color: #ff0000;"> line-height</span>:<span style="color: #0000ff;"> 0</span>; <span style="color: #008080;"> 8</span> <span style="color: #ff0000;"> overflow</span>:<span style="color: #0000ff;"> hidden</span>;</strong> <span style="color: #008080;"> 9</span> <span style="color: #ff0000;"> border-width</span>:<span style="color: #0000ff;"> 20px</span>; <strong><span style="color: #008080;">10</span> <span style="color: #ff0000;"> border-style</span>:<span style="color: #0000ff;"> dashed dashed solid dashed</span>; <span style="color: #008080;">11</span> <span style="color: #ff0000;"> border-color</span>:<span style="color: #0000ff;"> transparent transparent yellow transparent</span>;</strong> <span style="color: #008080;">12</span> }</span>
登录后复制
解释:
①border-color: transparent transparent yellow transparent;
因为我们要的是上三角,根据图2,我们要保留的是下边框,故把其他三条边设为transparent;
②border-style: dashed dashed solid dashed;
把其他三边设为dashed,是因为IE6不支持透明属性transparent,故我们把其它三边的样式设为
dashed,dashed在边框宽度很大时,会隐藏。(因为我的电脑没有ie6,所以没有实践过,这一点有点抱歉)
③font-size: 0; line-height: 0; overflow: hidden;
如果不加这三句,会出现以下效果:

t.png)
④最后多加了两句css hack: *width: 40px; *height: 40px;
当时用IE测试效果时,我发现根本找不到小三角,在网上搜各种博客也搜不到相关问题,后来随手加了句
width&height的样式,小三角就出现了,感觉应该是在IE下,div的宽高是包括border的(对于这点还是不太懂,希望有大牛给予解答)。
为了解决IE下的这个问题,我最后就加了这两句css hack。如果觉得不保险,还可以再加上" _width: 40px; _height: 40px;"
PS: ① IE6和IE7能识别"*",IE6能识别"_",具体搜索“CSS hack”。
② *width应设为 border-width 的两倍,*height同理。
对于下三角,左三角,右三角,只需改变上三角中的两句CSS即可,其他无需改变,改变的代码分别如下所示。
下三角:


<span style="color: #800000; font-size: 15px;">border-style: solid dashed dashed dashed; border-color: lightgreen transparent transparent transparent;</span>
登录后复制
左三角:


<span style="color: #800000; font-size: 15px;">border-style: dashed solid dashed dashed; border-color: transparent pink transparent transparent;</span>
登录后复制

q.png)
<span style="color: #800000; font-size: 15px;">border-style: dashed dashed dashed solid; border-color: transparent transparent transparent lightblue;</span>
登录后复制
最后,给出效果图1的代码:
<span style="font-size: 15px;"><span style="color: #008080;"> 1</span> <span style="color: #008000;">/*</span><span style="color: #008000;"> css </span><span style="color: #008000;">*/</span> <span style="color: #008080;"> 2</span> <span style="color: #800000;">*</span>{ <span style="color: #008080;"> 3</span> <span style="color: #ff0000;"> margin</span>:<span style="color: #0000ff;"> 0px</span>; <span style="color: #008080;"> 4</span> <span style="color: #ff0000;"> padding</span>:<span style="color: #0000ff;"> 0px</span>; <span style="color: #008080;"> 5</span> <span style="color: #ff0000;"> text-align</span>:<span style="color: #0000ff;"> center</span>; <span style="color: #008080;"> 6</span> } <span style="color: #008080;"> 7</span> <span style="color: #800000;">#container</span>{ <span style="color: #008080;"> 8</span> <span style="color: #ff0000;"> position</span>:<span style="color: #0000ff;"> relative</span>;<span style="color: #ff0000;"> //这句很重要,因为小三角是相对父元素#container来绝对定位的 </span><span style="color: #008080;"> 9</span> <span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 50px</span>; <span style="color: #008080;">10</span> <span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 40px</span>; <span style="color: #008080;">11</span> <span style="color: #ff0000;"> border</span>:<span style="color: #0000ff;">1px solid lightblue</span>; <span style="color: #008080;">12</span> <span style="color: #ff0000;"> margin</span>:<span style="color: #0000ff;"> 200px auto</span>; <span style="color: #008080;">13</span> <span style="color: #ff0000;"> padding</span>:<span style="color: #0000ff;"> 20px</span>; <span style="color: #008080;">14</span> <span style="color: #008080;">15</span> } <span style="color: #008080;">16</span> <span style="color: #800000;">#chat</span>{ <span style="color: #008080;">17</span> <span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 50px</span>; <span style="color: #008080;">18</span> <span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 40px</span>; <span style="color: #008080;">19</span> <span style="color: #ff0000;"> background-color</span>:<span style="color: #0000ff;"> lightblue</span>; <span style="color: #008080;">20</span> } <span style="color: #008080;">21</span> <span style="color: #800000;">#triangle</span>{ <span style="color: #008080;">22</span> <span style="color: #ff0000;"> position</span>:<span style="color: #0000ff;"> absolute</span>;<span style="color: #ff0000;"> //设置小三角绝对定位 </span><span style="color: #008080;">23</span> <span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 0px</span>; <span style="color: #008080;">24</span> <span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 0px</span>; <span style="color: #008080;">25</span> <span style="color: #ff0000;"> *width</span>:<span style="color: #0000ff;"> 14px</span>; <span style="color: #008080;">26</span> <span style="color: #ff0000;"> *height</span>:<span style="color: #0000ff;"> 14px</span>; <span style="color: #008080;">27</span> <span style="color: #ff0000;"> font-size</span>:<span style="color: #0000ff;"> 0</span>; <span style="color: #008080;">28</span> <span style="color: #ff0000;"> line-height</span>:<span style="color: #0000ff;"> 0</span>; <span style="color: #008080;">29</span> <span style="color: #ff0000;"> overflow</span>:<span style="color: #0000ff;"> hidden</span>; <span style="color: #008080;">30</span> <span style="color: #ff0000;"> border-width</span>:<span style="color: #0000ff;"> 7px</span>; <span style="color: #008080;">31</span> <span style="color: #ff0000;"> border-style</span>:<span style="color: #0000ff;"> dashed dashed dashed solid</span>; <span style="color: #008080;">32</span> <span style="color: #ff0000;"> border-color</span>:<span style="color: #0000ff;"> transparent transparent transparent lightblue</span>; <span style="color: #008080;">33</span> <span style="color: #ff0000;"> top</span>:<span style="color: #0000ff;"> 33px</span>;<span style="color: #ff0000;"> //33px:父元素#container的内边距20px + #chat宽度的一半20px - 自身元素#triangle的边宽7px =33px </span><span style="color: #008080;">34</span> <span style="color: #ff0000;"> left</span>:<span style="color: #0000ff;"> 70px</span>;<span style="color: #ff0000;"> //70px</span>:<span style="color: #0000ff;"> #chat的宽度50px + 父元素#container的内边距20px =70px </span><span style="color: #008080;">35</span> }</span>
登录后复制
<span style="font-size: 15px;"><span style="color: #008000;">/*</span><span style="color: #008000;"> html代码 </span><span style="color: #008000;">*/</span><span style="color: #800000;"> <div id="container"> <div id="chat"></div> <div id="triangle"></div> </div></span></span>
登录后复制
如有不足之处,欢迎批评建议, O(∩_∩)O谢谢
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前
By 尊渡假赌尊渡假赌尊渡假赌
刺客信条阴影:贝壳谜语解决方案
2 周前
By DDD
R.E.P.O.如果您听不到任何人,如何修复音频
1 个月前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
1 个月前
By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

本文讨论了HTML&lt; Progress&gt;元素,其目的,样式和与&lt; meter&gt;元素。主要重点是使用&lt; progress&gt;为了完成任务和LT;仪表&gt;对于stati

本文讨论了html&lt; datalist&gt;元素,通过提供自动完整建议,改善用户体验并减少错误来增强表格。Character计数:159

本文讨论了使用HTML5表单验证属性,例如必需的,图案,最小,最大和长度限制,以直接在浏览器中验证用户输入。

本文讨论了HTML&lt; meter&gt;元素,用于在一个范围内显示标量或分数值及其在Web开发中的常见应用。它区分了&lt; meter&gt;从&lt; progress&gt;和前

本文讨论了视口元标签,这对于移动设备上的响应式Web设计至关重要。它解释了如何正确使用确保最佳的内容缩放和用户交互,而滥用可能会导致设计和可访问性问题。

本文讨论了&lt; iframe&gt;将外部内容嵌入网页,其常见用途,安全风险以及诸如对象标签和API等替代方案的目的。

HTML适合初学者学习,因为它简单易学且能快速看到成果。1)HTML的学习曲线平缓,易于上手。2)只需掌握基本标签即可开始创建网页。3)灵活性高,可与CSS和JavaScript结合使用。4)丰富的学习资源和现代工具支持学习过程。
