>웹 프론트엔드 >HTML 튜토리얼 >元素形状之“自适应的椭圆”_html/css_WEB-ITnose

元素形状之“自适应的椭圆”_html/css_WEB-ITnose

WBOY
WBOY원래의
2016-06-21 08:45:511203검색

设计场景


  • 有时候我们不给元素指定固定的宽高,是希望它能 根据内容自动调整并适应
  • 如果宽高相等,就显示为一个圆;如果宽高不等,就显示为一个椭圆

解决方案


结构

<div class="box">    <!-- 自适应的椭圆内容 --></div>

风格

.box {  width: 200px;  height: 200px;  border-radius: 50%;}

说明:这个百分比值是基于 元素的尺寸进行解析

写到这里小编提问:如何实现半椭圆呢?


  • 沿横轴劈开的上半椭圆结构

    <div class="box">  <!-- 半椭圆内容 --></div>

    风格

    .box {width: 256px;height: 160px;background-color: #fb3;border-radius: 50% / 100% 100% 0 0;}
  • 沿横轴劈开的下半椭圆结构

    <div class="box">  <!-- 半椭圆内容 --></div>

    风格

    .box {width: 256px;height: 160px;background-color: #fb3;border-radius: 50% / 0 0 100% 100%;}
  • 沿纵轴劈开的左半椭圆结构

    <div class="box">  <!-- 半椭圆内容 --></div>

    风格

    .box {width: 256px;height: 160px;background-color: #fb3;border-radius:  100% 0 0 100% / 50%;}
  • 沿纵轴劈开的右半椭圆结构

    <div class="box">  <!-- 半椭圆内容 --></div>

    风格

    .box {width: 256px;height: 160px;background-color: #fb3;border-radius:  0 100% 100% 0 / 50%;}

说明:border-radius 属性可以 单独指定水平和垂直半径,只要用一个斜杠(/)分隔这两个值即可

写到这里小编再次提问:如何实现四分之一椭圆呢?


结构

<div class="box">    <!-- 半椭圆内容 --></div>

风格

.box {  width: 256px;  height: 160px;  background-color: #fb3;  border-radius:  100% 0 0 0;}

说明:创建四分之一椭圆要满足的条件,其中一个角的水平和垂直半径值都设为100%,其它三个角都设为0

《CSS SECRETS》

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.