CSS3的calc()使用

一.什么是calc()?###

calc()从字面我们可以把他理解为一个函数function。其实calc是英文单词calculate(计算)的缩写,是css3的一个新增的功能,用来指定元素的长度。比如说,你可以使用calc()给元素的border、margin、pading、font-size和width等属性设置动态值。为何说是动态值呢?因为我们使用的表达式来得到的值。不过calc()最大的好处就是用在流体布局上,可以通过calc()计算得到元素的宽度。著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

二.calc()能做什么?###

calc()能让你给元素的做计算,你可以给一个div元素,使用百分比、em、px和rem单位值计算出其宽度或者高度,比如说“width:calc(50% + 2em)”,这样一来你就不用考虑元素DIV的宽度值到底是多少,而把这个烦人的任务交由浏览器去计算。著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

三.calc()语法###

   .elm{
         width:calc( expression)
   }
   其中“expression”是一个表达式,用来计算长度的表达式

1.使用“+”、“-”、“” 和 “/”四则运算;
2.可以使用百分比、px、em、rem等单位;
3.可以混合使用各种单位进行计算;
4.表达式中有“+”和“-”时,其前后必须要有空格,如"widht: 5.calc(12%+5em)"这种没有空格的写法是错误的;
6.表达式中有“
”和“/”时,其前后可以没有空格,但建议留有空格。

四.实例###

      <style>
        .demo { 
              width: 300px; 
              background: #60f; 
              padding: 3px 0;
         }
        .box { 
              background: #f60;
              height: 50px; 
              padding: 10px;
              border: 5px solid green;
              width: 90%;
             /*写给不支持calc()的浏览器*/ 
             width:-moz-calc(100% - (10px + 5px) * 2);
             width:-webkit-calc(100% - (10px + 5px) * 2); 
             width: calc(100% - (10px + 5px) * 2);
         }
      </style>
      <div class="demo"> <div class="box"></div></div>
css3-calc-step3.jpg
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 摘自http://www.w3cplus.com/css3/how-to-use-css3-calc-functi...
    Lareina林暖暖阅读 781评论 0 0
  • 什么是calc()? 学习calc()之前,我们有必要先知道calc()是什么?只有知道了他是个什么东东?在实际运...
    ddai_Q阅读 417评论 0 1
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,806评论 1 92
  • 作者:HelKyle链接:http://www.w3cplus.com/css/when-to-use-em-vs...
    红叶丶秋鸣阅读 3,304评论 0 3
  • 在制作页面的时候,总会碰到有的元素是100%的宽度。如果元素宽度为100%时,其自身不带其他盒模型属性设置还好,要...
    wavesnow阅读 1,161评论 0 1