在页面编写中经常会碰到页面自适应的问题,也就是页面内部的元素会随着窗口的放大缩小而放大缩小,box可以通过calc + 百分比的形式做到页面自适应,但是box内的字体却无法做到这点,往往box自适应大小了,内部的字体还是原来的大小,看起来会非常别扭,下面就来css实现一下页面文字的自适应大小。

clamp()函数

这里主要用到clamp()函数,clamp() 函数的作用是把一个值限制在一个上限和下限之间,当这个值超过最小值和最大值的范围时,在最小值和最大值之间选择一个值使用。它接收三个参数:最小值、首选值、最大值。
当首选值比最小值要小时,则使用最小值。
当首选值介于最小值和最大值之间时,用首选值。
当首选值比最大值要大时,则使用最大值。

clamp()的文档:https://developer.mozilla.org/zh-CN/docs/Web/CSS/clamp

我们可以通过在clamp()内设置表达式,来动态的设置文字的大小,比如这里有一个视口,最小320px,最大1200px,当视口小于320px的时候字体大小为0.7rem,当视口大小大于1200px的时候,字体大小为1.2rem,否则就使用区间的首选值。

.clampSize{width: 100%; /* 可以动态设置大小 */height: 40px;margin: 30px;line-height: 40px;text-align: center;border: 1px solid red;font-size:clamp(0.7rem, 0.489rem + 1.05vw, 1.2rem);  /* 通过动态计算首选值实现响应式字体变化 */
}


有人说这个值我不知道该设置多大,那么你可以用这个网站:https://min-max-calculator.9elements.com/

左边是你的参数范围,右边是你的视口大小,还是非常方便的啦~

实现了这个之后,我们就可以开始着手实现响应式布局的文字大小自适应了,下面案例中,视口最小320px,最大1200px,文字取值最小0.7rem,最大1.2rem,否则取首选值。

<div class="useClamp"><div>女装</div><div>童鞋</div><div>箱包</div><div>首饰挂件</div>
</div>
.useClamp{width: 80%; /*容器大小自适应*/height: 30px;padding-left: 10px;display: flex;align-items: center;direction: ltr;background: #eee;>div{min-width: 60px;width: 30%;  /*按钮大小自适应*/height: 30px;background: #4d90fe;color: white;display: flex;align-items: center;justify-content: space-around;border-radius: 4px;margin-inline-end: 10px;font-size: clamp(0.7rem, 0.489rem + 1.05vw, 1.2rem);  /*文字大小自适应,最小0.7rem,最大1.2rem,否则取首选值*/}
}


大小的上下限制

min()函数

当我们想要给box设置一个宽度,最小为屏幕的80%,最大为1000px,通常会这么写:

.box{width: 80%;
max-width: 1000px;
}

这种写法可以实现容器的最大和最小的宽度限制,有了min()函数后,可以一句css声明即可实现。

min() 方法拥有一个或多个逗号分隔符表达式作为参数,表达式的值中最小的值作为参数值。
语法:min(expression [, expression])
其实就是设置最小值为最大值,我们来看一个案例:

.minSize{width:min(80%,1000px ); /* 可以动态设置大小,屏幕宽度大于1000px则宽度为1000px(因为1000比80%小),小于1000px则宽度为80%(此时80%比1000小)*/height: 40px;border: 1px solid red;
}


这里 width:min(100%,1024px ); 就是说:屏幕宽度大于1000px则宽度为1000px(因为100080%小),小于1000px则宽度为80%(此时80%1000小)。

注意:min()函数参数需要百分比值,如果是固定px值将会失效。


max()函数

max()函数其实和min()函是数一样的效果,只不过这里取的是最大值为最小值

.maxSize{width:max(90%,1024px); /* max()函数和min()函数语法类似,区别在于max()函数返回的是最大值,min()函数返回的是最小值。 可以动态设置大小,屏幕宽度90%大于1024px则用90%,若屏幕宽度90%小于1024px则用2014px*/height: 40px;border: 1px solid red;margin-top: 40px;
}

width:max(90%,1024px);的意思是:屏幕宽度90%大于1024px则用90%,若屏幕宽度90%小于1024px则用2014px


案例源码:https://gitee.com/wang_fan_w/css-diary

如果觉得这篇文章对你有帮助,欢迎点赞、收藏、转发哦~

css实现文字大小自适应相关推荐

  1. konva文字大小自适应容器宽度

    简单记录konva字体缩放的使用方法 //Konva使用的基本案例 //第一步:创建舞台 var stage = new Konva.Stage({container: 'container', // ...

  2. 手机html根据手机分辨率网页文字大小自适应

    问题:不同手机型号屏幕尺寸大不相同,导致同样的文字,有的显示一行,有的显示多行. 通过查资料和自己的尝试解决:网页开发习惯的px单位,手机html开发不适用. 源代码如下: <!DOCTYPE ...

  3. css文字大小自适应

    总结了一下一些单位的不同 px:像素(pixel)相对长度单位,,是相对于屏幕显示器分辨率而言的: em:em的值并不是固定的,会集成父级元素的字体大小: 注意: 1.body选择其中声明Font-s ...

  4. Echarts文字大小自适应,案例详解

    用echarts做可视化大屏的时候,图表大小可以自适应,但是图表里面文字的大小不能自适应.有一种解决方法就是采用rem为单位,根据屏幕的宽度调整html的font-size. <div id=& ...

  5. 【UGUI】UGUI 文字背景根据文字大小自适应

    在使用UGUI 的时候经常会做文字的适配,就是当文字字数超出文本以后让文本随字体的数量增加而加长或加宽,当有背景去做适配的时候如何去做呢? 道理是一样的 在text + contentSizeFitt ...

  6. html5纯css字体大小自适应设置

    css 字体大小自适应样式设置篇 字体可以设置大小使用css font-size来实现,有时需要对字体大小根据浏览器分辨率来判断后自适应大小. 在CSS 2.0中字体大小自适应是难实现的,一般使用JS ...

  7. FastReport 自适应列文字大小

    1,  点击cell 文字大小自适应, 高度自适应我一直没调出来, 希望有懂的留言. Auto Shrink = FontWidth

  8. html中字段间距代码,css调字体大小代码 css字与字之间的间距怎么调

    html怎么改变字体大小和颜色 可以用css改变字体的大小和颜色. 在head标签中添加style标签给页面设置css样式,选择p标签,字体大小用的是"font-size"属 在D ...

  9. html里字号rem,html中的em和rem到底该如何使用,自适应效果中如何确定文字大小/字号?...

    如今手机屏幕繁多,自适应效果中如何确定文字大小/字号? em rem vm vw vh你都了解吗? 先说说em和rem em:继承父级的,假设html的font-size默认为16px,body字体大 ...

最新文章

  1. spring security remember me实现自动登录
  2. Facebook 开源标准卷积替代方案 OctConv
  3. 数据科学家技能地铁图
  4. ibatis annotations 注解方式返回刚插入的自增长主键ID的值--转
  5. Vue在插槽slot时报错:Component template should contain exactly one root element. If you are using v-ifen
  6. C# DataSet性能最佳实践
  7. 登陆mysql服务器命令_Mysql服务器登陆,启动,停止等基本操作命令介绍(Linux/Centos环境)...
  8. java基础知识点(4)——运算符与键盘录入
  9. Web Hacking 101 中文版 十一、SQL 注入
  10. tlc5620输出三角波流程图_[笔记].串型DAC TLC5620生成锯齿波、三角波实验,Verilog版本...
  11. 【基础概念大总结】— 网络安全 Java 基础知识大汇总
  12. 基于stm32的智能风扇设计
  13. 贝叶斯分析思路 通俗讲法
  14. 12个不容错过的Vue UI 组件库
  15. 【语音信号处理课程设计】基于MATLAB的隐马尔可夫和矢量量化的语音识别研究
  16. docker的一些使用技巧
  17. 笔记本损耗60 计算机提示,笔记本电池损耗60%多怎么处理!
  18. becon帧 wifi_beacon帧
  19. 简单实现 Android 闹钟
  20. Linux下安装bugzilla

热门文章

  1. 3、Kubernetes的基本使用
  2. 【ZJOI2017】仙人掌
  3. 设置网站ico图标的两种方法
  4. 磁盘IOPS概念及IOPS的计算与测试
  5. 【Android】GestureDetector 类的手势操作方法含义
  6. JAVA实现短信接口的调用
  7. idea提交git报401错误解决办法
  8. RAID的基本工作模式
  9. HDMI之EDID使用说明
  10. 家电售后服务外包维修模式,该如何管理