css3技术

Div+Css教程:cal()功能_div+css教程

字号+ 作者:H5之家 来源:H5之家 2015-09-15 14:19 我要评论( )

Div+Css教程:cal()功能,学习Div+Css教程:cal()功能,Div+Css教程:cal()功能,查看Div+Css教程:cal()功能,CSS3中有很多的隐藏的模块与功能。在这里我们将探索ca



   CSS3中有很多的隐藏的模块与功能。在这里我们将探索cal()功能;这个功能可能会改变你以前设计布局的方式,灰常的强悍~~

    CSS3的cal()功能是用来计算长度(lengths),数字(numbers),角度(angles),过渡(transition)/动画时间(animation times)或者声音频率(sound frequencies)。它将允许你使用混合计算类型—在CSS3中也是一个异常强大的概念。

   假设一个网站的设计要包含2个浮动的元素,你想要用一个60px的水平线将其分成2个相同宽度的元素,听起来似乎容易?如果页面设计的是960px,那么很容易,每个都是450px。

    但是如果改元素是一个浮动框或者动态的布局怎么办?如果页面设计的是600px,那么大部分的设计者将会将水平线设置为10%,剩下的各45%,在宽屏或者方屏的浏览窗口中将会变形或者有边距!

   幸运的是,新功能cal()功能允许women计算宽度。在上面的例子中,我们就可以将其设置为总宽度的50%-30px,例如:

#element1, #element2 { float: left; width: calc(50% - 30px); } #element2 { margin-left: 60px; }

如果你想让水平线的大小是相对于字体大小儿定,如4em,没问题:

#element1, #element2 { width: calc(50% - 2em); }

或者你想要在元素周围放一个2px的border,也没有问题:

#element1, #element2 { width: calc(50% - 2em - 4px); border: 2px solid #000; }

  但是建议尽量是计算简洁些,但是复杂的计算是能够实现的,例如:

#element1, #element2 { width: calc((50% + 2em)/2 + 14px); }

该元素的浏览器支持情况:

     Cla()功能是W3C推荐的功能,所以你会猜到哪个浏览器会一直支持?
也许你的猜测错了。在笔者写这篇文章的时候,只有IE9支持,Firefox也支持(需要其特有的前缀):-moz-cla()。Webkit内核的浏览器目前还没有支持(如Chrome和Safari)或者是Opera,改功能很有用的,相信用不了多久这些浏览器都会支持的。
幸运的是你可以在你的样式表(CSS )中使用增强样式:
element1, #element2 { width: 45%; /* all browsers */ width: -moz-calc(50% - 30px); /* Firefox 4+ */ width: calc(50% - 30px); /* IE9+ and future browsers */ }
请谨记你需要添加相应的调整(以面对不同的浏览器)。
#element2 { margin-left: 10%; /* all browsers */ margin-left: -moz-calc(60px); /* Firefox 4+ */ margin-left: calc(60px); /* IE9+ and future browsers */ }
CSS3 的min() 和 max()
    如果你喜欢cal()元素,你可能也会细化min()和max()功能,他们可以解释2个或2个以上用逗号隔开的元素值并且能够返回最大值或者最小值。
#myelement { width: max(300px, 30%, 30em); font-size: min(10px, 0.6em); }
这个功能在防止font过于大或者非常小的情况下很有用,但是不幸的是目前比较现代的浏览器都不支持min()和max()功能,我们只能默默期待浏览器

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
网友点评