使用 CSS 自动调整溢出文本的大小
我目前有以下代码:
<p style="font-size: 20em; max-width: 100vw;">Hellooo!</p>
正如您所看到的,字体大小对于屏幕来说太大了。我希望文本保持其设置的大小,直到溢出屏幕(我的尝试是最大宽度,但这不起作用)。有没有办法只用 CSS 和 HTML 来解决这个问题?
由于我希望文本大小为 20em
除非它溢出屏幕,所以我不想将 width
设置为 20em
以外的任何值。
谢谢!
I currently have the following code:
<p style="font-size: 20em; max-width: 100vw;">Hellooo!</p>
As you can see, the font-size is too large for the screen. I want the text to stay at its set size until it overflows the screen (My attempt is the max-width
, but that is not working). Is there a way to fix this with CSS and HTML only?
Since I want the text size to be 20em
unless it overflows the screen, I do not want to set the width
to any value other than 20em
.
Thanks!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
min
应该可以。使用已知字体,您还可以使用良好的后备。
min
should do it.With a known font, you can also use a good fallback.
如果您知道文本的长度,则可以使用 CSS min() 函数以及取决于视口的 em 大小和最大大小。否则你将需要一个polyfill。
If you know the length of text, you can use the CSS min() function with your em sizing and the maximum size dependent on the viewport. Otherwise you are going to need a polyfill.
您可以使用 CSS calc 函数并根据 vw 值更改字体大小。
You can use the CSS calc function and change the font size based on the vw value.
结合
media-queries
和变量单元(vw
)就能解决!A combination of
media-queries
and variable units(vw
) will solve!您可以使用以下 npm 库:
https://www.npmjs.com/package /@gmwallet/app-common
导入依赖项:
五个 id 到您的组件:
使用它:
这用于自动响应 DOM 元素,因此它对于动态数据可能更有用。例如,如果您的文本不是静态的,但假设它包含在名为“helloVar”的变量中,则可以将其放在监视语句中:
You can use the following npm library:
https://www.npmjs.com/package/@gmwallet/app-common
Import the dependency:
Five an id to your component:
Use it:
This is for automatically responsive DOM element, so it could be more useful with dynamic data. For example if your text is not static, but let's say that it is contained in a variable called "helloVar", you could put it in a watch statement: