css3中的calc函数浅析


Posted in HTML / CSS onJuly 10, 2018

前言

其实在之前学习CSS3的时候,我并没有注意到有calc()这个属性,后来在看一个大牛的代码的时候看到了这个,然后就引发了后来的一系列的查找、学习,以及这篇博客的诞生。好了,废话不多说了,来干正事。

简介

其实,calc()这个形式看起来就很容易让人想到Javascript里的函数,当然他不是js里的函数,但是他有着类似函数的功能,可以用来计算,括号里是一个表达式,通常用calc()来指定元素的长度,不管是width、height、border还是padding等都可以用他来指定。说白了,calc()就是css3的一个指定元素长度的属性,他的特殊之处在于他可以做计算,而且支持混合使用各种单位,比如%、px、em等。所以这个属性特别适用于那些自适应的布局。

兼容性:在IE9+、FF4.0+、Chrome19+、Safari6+都得到了较好支持(据说在使用时要加上供应商前缀,但是我测试了一下,不加也是可以用的),但是在移动端的支持不是很好。

正文:

最近在一次项目中我遇到一个很普通的问题,相信大家都会遇到过,我的需求是这样的,我的侧边栏的高度是百分百的,就像下面的例子一样:

css3中的calc函数浅析

这时我要在顶部导航栏上加一些需求,要实现的效果类似于这样,不过想很郁闷它出现了滚动条,效果如下:

css3中的calc函数浅析

我不想它出现滚动条,这个时候可能很多同学会说,我可以用绝对定位等等,但我的顶部导航栏本来就是绝对定位呀,于是乎我翻了一翻css3,发现了一个神奇的函数,calc!!!(啊尼路亚,啊尼路亚,啊尼路亚,啊尼路亚~~~)

下面是一些粗鄙的无聊的复制粘贴过来的函数说明:

calc() 函数用于动态计算长度值。

需要注意的是,运算符前后都需要保留一个空格,例如:width: calc(100vh - 10px);

任何长度值都可以使用calc()函数进行计算;

calc()函数支持 "+", "-", "*", "/" 运算;

calc()函数使用标准的数学运算优先级规则;

支持版本:CSS3

兼容性:(开头说了)

回到正事,了解了它的内容,接下来就要看看它能给你带来的好处,比如:消灭滚动条,当我把父级的高度设置成height: calc(100vh - '我的需求内容高度')时滚动条神奇的消失了,呈现了这样的效果:

css3中的calc函数浅析

登登登登~!!!是不是很神奇,为什么会这样呢?因为100vh就相当于window.innerHeight, 是浏览器的内部高度, 滚动条高度也计算在内。如果高只设置100%是可用高度, 就不包含滚动条的高度啦, 是不是非常好用的一个东西(说那么多大家走过路过应施舍点点赞给我,谢谢谢谢~)

其实不仅仅只有高,还有很多很多应用场景都是可以实现的,比如我们经常会给自己的ul li设置padding或者margin,当li的个数没有超过一定的数量时它是不会换到第二行的,但有时候就因为那么一点点padding或者margin就换行了,使得左边或者右边空白了一处很难看,大家都可以用calc这个函数去解决,我就不一一举例了哈,本人技术水平有限,就说到这了,如果有错的地方,希望大家可以多多指出,祝大家级别年年跳,薪资翻又翻。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

HTML / CSS 相关文章推荐
CSS3中border-radius属性设定圆角的使用技巧
May 10 HTML / CSS
细说CSS3中box属性中的overflow-x属性和overflow-y属性值的效果
Jul 21 HTML / CSS
css3学习系列之移动属性详解
Jul 04 HTML / CSS
CSS3动画特效在活动页中的应用
Jan 21 HTML / CSS
html5使用html2canvas实现浏览器截图的示例
Aug 31 HTML / CSS
html5如何及时更新缓存文件(js、css或图片)
Jun 24 HTML / CSS
HTML5中的autofocus(自动聚焦)属性介绍
Apr 23 HTML / CSS
移动端解决悬浮层(悬浮header、footer)会遮挡住内容的3种方法
Mar 27 HTML / CSS
深入理解HTML5定时器requestAnimationFrame的使用
Dec 12 HTML / CSS
基于Html5 canvas实现裁剪图片和马赛克功能及又拍云上传图片 功能
Jul 09 HTML / CSS
CSS3 制作的书本翻页特效
Apr 13 HTML / CSS
HTML+CSS实现导航条下拉菜单的示例代码
Aug 02 HTML / CSS
详解css3 object-fit属性
Jul 27 #HTML / CSS
CSS3对图片照片进行边缘模糊处理的实现
Aug 08 #HTML / CSS
详解CSS3伸缩布局盒模型Flex布局
Aug 20 #HTML / CSS
css3动画效果抖动解决方法
Sep 03 #HTML / CSS
微信小程序实现可实时改变转速的css3旋转动画实例代码
Sep 11 #HTML / CSS
CSS3 background-image颜色渐变的实现代码
Sep 13 #HTML / CSS
基于CSS3实现的几个小loading效果
Sep 27 #HTML / CSS
You might like
图书管理程序(三)
2006/10/09 PHP
几种显示数据的方法的比较
2006/10/09 PHP
Discuz 6.0+ 批量注册用户名
2009/09/13 PHP
详解Laravel视图间共享数据与视图Composer
2016/08/04 PHP
PHP自定义函数获取汉字首字母的方法
2016/12/01 PHP
php 提交表单 关闭layer弹窗iframe的实例讲解
2018/08/20 PHP
用javascript将数据库中的TEXT类型数据动态赋值到TEXTAREA中
2007/04/20 Javascript
[原创]js获取数组任意个不重复的随机数组元素
2010/03/15 Javascript
JS 加入收藏夹的代码(主流浏览器通用)
2013/05/13 Javascript
javascript校验价格合法性实例(必须输入2位小数)
2014/05/05 Javascript
JavaScript实现网页对象拖放功能的方法
2015/04/15 Javascript
jQuery背景插件backstretch使用指南
2015/04/21 Javascript
JavaScript中的Math.atan2()方法使用详解
2015/06/15 Javascript
全面解析Bootstrap表单样式的使用
2016/09/09 Javascript
jQuery实现磁力图片跟随效果完整示例
2016/09/16 Javascript
一次让你了解全部JavaScript的作用域
2019/06/24 Javascript
Vue实现图书管理小案例
2020/12/03 Vue.js
Python多进程机制实例详解
2015/07/02 Python
python安装cx_Oracle模块常见问题与解决方法
2017/02/21 Python
Sanic框架Cookies操作示例
2018/07/17 Python
python3.6利用pyinstall打包py为exe的操作实例
2018/10/31 Python
初次部署django+gunicorn+nginx的方法步骤
2019/09/11 Python
Python基于traceback模块获取异常信息
2020/07/23 Python
Lookfantastic日本官网:英国知名护肤、化妆品和头发护理购物网站
2018/04/21 全球购物
Nike墨西哥官网:Nike MX
2020/08/30 全球购物
简单说说tomcat的配置
2013/05/28 面试题
中年人生感言
2014/02/04 职场文书
财务支持类个人的自我评价
2014/02/14 职场文书
《鸟的天堂》教学反思
2014/02/27 职场文书
学术诚信承诺书
2014/05/26 职场文书
纪念九一八事变演讲稿:牢记九一八,屈辱怎能忘
2014/09/14 职场文书
退休职工欢送会致辞
2015/08/01 职场文书
python基于tkinter实现gif录屏功能
2021/05/19 Python
Apache Hudi集成Spark SQL操作hide表
2022/03/31 Servers
Redis实战高并发之扣减库存项目
2022/04/14 Redis
golang使用map实现去除重复数组
2022/04/14 Golang