CSS中三角形相关
上三角形
1 2 3 4 5 6 7
| #top{ width: 0; height: 0; border-bottom: 20px solid #fff; border-left: 20px solid transparent; border-right: 20px solid transparent; }
|
左三角形
1 2 3 4 5 6 7
| #left{ width: 0; height: 0; border-right: 20px solid #fff; border-bottom: 20px solid transparent; border-top: 20px solid transparent; }
|
右上三角形
1 2 3 4 5 6
| #rightbottom{ width: 0; height: 0; border-right: 20px solid #fff; border-bottom: 20px solid transparent; }
|
左上三角形
1 2 3 4 5 6
| #lefttop{ width: 0; height: 0; border-left: 20px solid #fff; border-bottom: 20px solid transparent; }
|
原理
一个div的四条border如果不同颜色话
data:image/s3,"s3://crabby-images/0c442/0c4421f7cd5033caea7a8ed7491643f91bcfa58f" alt="div with border"
再将width
和height
清零
data:image/s3,"s3://crabby-images/30f7b/30f7be1993a7731a2175fc4a42de5bc70a98d91c" alt="div with no content"
一个top的三角形需要transparent
的border-left
和border-right
撑起来
data:image/s3,"s3://crabby-images/0237a/0237a2d6b4299be33598e607de1d5bdaee3ee1ad" alt="top triangle"
如果缺少border-left
data:image/s3,"s3://crabby-images/4bc52/4bc52547102fb15fd7649f3a07d4bdf3fd5ca889" alt="no border left"
可以想象出,对于top的三角形,border-left
和border-right
设置三角形的宽度,border-bottom
设置三角形的高度
应用对话框
data:image/s3,"s3://crabby-images/4dac6/4dac6a2b2044d758d6977afeede40f1a0d5222de" alt="dialog"
1 2 3 4 5 6 7 8
| #dialog{ position: relative; width: 120px; height: 50px; margin-left: 30px; background: red; border-radius: 10px; }
|
1 2 3 4 5 6 7 8 9 10 11
| #dialog:before{ position: absolute; content:""; right:100%; top: 12px; width: 0; height: 0; border-top: 13px solid transparent; border-bottom: 13px solid transparent; border-right: 13px solid red; }
|
CSS中圆形相关
圆圈
1 2 3 4 5 6
| .circle { width: 100px; height: 100px; border-radius: 50px; border: 1px #6C93D0 solid; }
|
data:image/s3,"s3://crabby-images/2185e/2185e624046662555576b46d2b9f13d3e013ba52" alt="circle"
圆形
1 2 3 4 5 6
| .roundness{ width: 100px; height: 100px; border-radius: 50px; background-color: #6C93D0; }
|
data:image/s3,"s3://crabby-images/cc8c2/cc8c2b0bf5afd7fcebbfcf7850af02217005a309" alt="roundness"
原理
原理一看就明白啦,不再赘述。border-radius
按道理是宽高的一半即可,超过也会显示正常。