我想知道是否有比我现在做的更简单的方法来创建圆形 div。
目前,我只是为每种不同的尺寸制作一个图像,但这样做很烦人。
无论如何使用CSS来制作圆形的div,我可以指定半径吗?
我想知道是否有比我现在做的更简单的方法来创建圆形 div。
目前,我只是为每种不同的尺寸制作一个图像,但这样做很烦人。
无论如何使用CSS来制作圆形的div,我可以指定半径吗?
这是一个演示:http: //jsfiddle.net/thirtydot/JJytE/1170/
CSS:
.circleBase {
border-radius: 50%;
behavior: url(PIE.htc); /* remove if you don't care about IE8 */
}
.type1 {
width: 100px;
height: 100px;
background: yellow;
border: 3px solid red;
}
.type2 {
width: 50px;
height: 50px;
background: #ccc;
border: 3px solid #000;
}
.type3 {
width: 500px;
height: 500px;
background: aqua;
border: 30px solid blue;
}
HTML:
<div class="circleBase type1"></div>
<div class="circleBase type2"></div><div class="circleBase type2"></div>
<div class="circleBase type3"></div>
要在IE8 和更早版本中使用此功能,您必须下载并使用CSS3 PIE。我上面的演示在 IE8 中不起作用,但这只是因为 jsFiddle 不托管PIE.htc
.
我的演示如下所示:
将元素每一侧的边框半径设置为 50% 将创建任意大小的圆形显示:
.circle {
border-radius: 50%;
width: 200px;
height: 200px;
/* width and height can be anything, as long as they're equal */
}
尝试这个
.iphonebadge {
border-radius:99px;
-moz-border-radius:99px;
-webkit-border-radius:99px;
background:red;
color:#fff;
border:3px #fff solid;
background-color: #e7676d;
background-image: -webkit-gradient(linear, left top, left bottom, from(#e7676d), to(#b7070a)); /* Saf4+, Chrome */
background-image: -webkit-linear-gradient(top, #e7676d, #b7070a); /* Chrome 10+, Saf5.1+, iOS 5+ */
background-image: -moz-linear-gradient(top, #e7676d, #b7070a); /* FF3.6 */
background-image: -ms-linear-gradient(top, #e7676d, #b7070a); /* IE10 */
background-image: -o-linear-gradient(top, #e7676d, #b7070a); /* Opera 11.10+ */
background-image: linear-gradient(top, #e7676d, #b7070a);
filter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#e7676d', EndColorStr='#b7070a');
-webkit-box-shadow: 0px 2px 4px #000000; /* Saf3-4 */
-moz-box-shadow: 0px 2px 4px #000000; /* FF3.5 - 3.6 */
box-shadow: 0px 2px 4px #000000; /* Opera 10.5, IE9, FF4+, Chrome 10+ */
display:inline-block;
padding:2px 2px 2px 2px ;
margin:3px;
font-family:arial;
font-weight:bold;
}
这实际上是可能的。
请参阅:CSS 提示:如何制作没有图像的圆圈。见演示。
但是请注意,它基本上在兼容性方面存在严重的缺点,您正在制作猫皮。
看到它在 这里工作
如您所见,您只需将height
and设置width
为一半border-radius
祝你好运!
还有 [坏主意] 使用几个 (20+) 水平或垂直 1px div 来构建一个圆圈。这个 jQuery 插件使用这种方法来构造不同的形状。
根据大小给出宽度和高度,但要保持相等
.circle {
background-color: gray;
height: 400px;
width: 400px;
border-radius: 100%;
}
<div class="circle">
</div>
我有 4 个解决方案来完成这项任务:
#circle1 {
background-color: #B90136;
width: 100px;
height: 100px;
border-radius: 50px;/* specify the radius */
}
#circle2 {
background-color: #B90136;
width: 100px;/* specify the radius */
height: 100px;/* specify the radius */
clip-path: circle();
}
#circle3::before {
content: "";
display: block;
width: 100px;
height: 100px;
border-radius: 50px;/* specify the radius */
background-color: #B90136;
}
#circle4 {
background-image: radial-gradient(#B90136 70%, transparent 30%);
height: 100px;/* specify the radius */
width: 100px;/* specify the radius */
}
<h3>1 border-radius</h3>
<div id="circle1"></div>
<hr/>
<h3>2 clip-path</h3>
<div id="circle2"></div>
<hr/>
<h3>3 pseudo element</h3>
<div id="circle3"></div>
<hr/>
<h3>4 radial-gradient</h3>
<div id="circle4"></div>
.fa-circle{
color: tomato;
}
div{
font-size: 100px;
}
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet"/>
<div><i class="fa fa-circle" aria-hidden="true"></i></div>
只是想提一下另一个解决方案,它回答了“创建圆形 div 比使用图像更简单的方法?”这个问题。也就是使用 FontAwesome。
您从此处导入 fontawesome css 文件或从 CDN
然后你就:
<div><i class="fa fa-circle" aria-hidden="true"></i></div>
你可以给它任何你想要任何字体大小的颜色。
.circle {
height: 20rem;
width: 20rem;
border-radius: 50%;
background-color: #EF6A6A;
}
<div class="circle"></div>
你可以试试radial-gradient
CSS 函数:
.circle {
width: 500px;
height: 500px;
border-radius: 50%;
background: #ffffff; /* Old browsers */
background: -moz-radial-gradient(center, ellipse cover, #ffffff 17%, #ff0a0a 19%, #ff2828 40%, #000000 41%); /* FF3.6-15 */
background: -webkit-radial-gradient(center, ellipse cover, #ffffff 17%,#ff0a0a 19%,#ff2828 40%,#000000 41%); /* Chrome10-25,Safari5.1-6 */
background: radial-gradient(ellipse at center, #ffffff 17%,#ff0a0a 19%,#ff2828 40%,#000000 41%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
}
将其应用于div
图层:
<div class="circle"></div>
假设您有这张图片:
用这个圈出你只需要添加
.circle {
border-radius: 50%;
width: 100px;
height: 100px;
}
所以如果你有一个 div 你可以做同样的事情。
检查以下示例:
.circle {
border-radius: 50%;
width: 100px;
height: 100px;
animation: stackoverflow-example infinite 20s linear;
pointer-events: none;
}
@keyframes stackoverflow-example {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
<div>
<img class="circle" src="https://www.sitepoint.com/wp-content/themes/sitepoint/assets/images/icon.javascript.png">
</div>
您可以使用 radius 但它不适用于 IE: border-radius: 5px 5px;
。
基本上,这使用 div 的绝对位置将字符放置在给定坐标处。所以使用圆的参数方程,你可以画一个圆。如果您要将 div 的位置更改为相对位置,则会产生正弦波...
本质上,我们通过滥用位置属性来绘制方程。我不精通css,所以肯定有人可以使它更优雅。请享用。
这适用于所有浏览器和移动设备(我知道)。我在我自己的网站上使用它来绘制文本的正弦波(www.cpixel.com)。此代码的原始来源可在此处找到:www.mathopenref.com/coordcirclealgorithm.html
<html>
<head></head>
<body>
<script language="Javascript">
var x_center = 50; //0 in both x_center and y_center will place the center
var y_center = 50; // at the top left of the browser
var resolution_step = 360; //how many times to stop along the circle to plot your character.
var radius = 50; //how big ya want your circle?
var plot_character = "·"; //could use any character here, try letters/words for cool effects
var div_top_offset=10;
var div_left_offset=10;
var x,y;
for ( var angle_theta = 0; angle_theta < 2 * Math.PI; angle_theta += 2 * Math.PI/resolution_step ){
x = x_center + radius * Math.cos(angle_theta);
y = y_center - radius * Math.sin(angle_theta);
document.write("<div style='position:absolute;top:" + (y+div_top_offset) + ";left:"+ (x+div_left_offset) + "'>" + plot_character + "</div>");
}
</script>
</body>
</html>
添加以下css
属性:
border-radius: 50%;
对任何 div 使其循环。
对于圆形,创建一个 div 元素,然后输入宽度 = 2 倍的边框半径 = 2 倍的填充。还有 line-height = 0 例如,以 50px 作为圆的半径,下面的代码运行良好:
width: 100px;
padding: 50px 0;
border: solid;
line-height: 0px;
border-radius: 50px;