0


css实现文字大小自适应

在页面编写中经常会碰到页面自适应的问题,也就是页面内部的元素会随着窗口的放大缩小而放大缩小,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

,否则取首选值。

<divclass="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

(因为

1000

80%

小),小于

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 前端 html

本文转载自: https://blog.csdn.net/qq_44793507/article/details/129629040
版权归原作者 DCodes 所有, 如有侵权,请联系我们删除。

“css实现文字大小自适应”的评论:

还没有评论