javascript实现一行文字随不同设备自适应改变字体大小至字数完全展示
产品提了一个小需求,希望一行能展示用户输入的所有文字,因为最多限制为25字符,但是如果夹杂英文/韩文/日文等,即使字符数是一样的,但是展示的长度不一样,则有些title标题会被截断。
效果如图

前提是总字数有一个差不多展示一行的最大限制,否则文字太小,也不能保证正常展示。
.lineClamp {
overflow: hidden !important;
text-overflow: ellipsis !important;
-webkit-line-clamp:;
display: -webkit-box;
-webkit-box-orient: vertical;
white-space: normal;
}
<div id="titleBox">
<div class="title" id="title">
哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈啊哈哈哈
</div>
</div>
//title字体大小自适应,以能完全在一行显示25个不同类型的字符。
function fontAuto() {
let titleBox = document.getElementById("titleBox");
let title=document.getElementById("title");
let size=4;
title.style.fontSize = size + 'vw';
let scrollWidth=title.scrollWidth;
while (title.scrollWidth > document.getElementById("titleBox").offsetWidth) {
scrollWidth=title.scrollWidth;
//当容器高度大于最大高度的时候,上一个尝试的值就是最佳大小。
size=size-0.2;
title.style.fontSize = size+ 'vw';
if(scrollWidth<=title.scrollWidth){
$("#title").addClass("lineClamp1");
$("#title").removeClass("toh");
break;
}
}
}
fontAuto();
思路:由于不同移动设备的分辨率不同,这里给font-size用的单位为vw,默认设置一个当前字体的font-size,获取到文字外层容器的宽度,判断文字的宽度是否大于容器的宽度,如果大于,则给当前的font-size减小0.1vw,如果px同理,可以按减小1px计算,然后成功,如果在一些小屏幕设备上,字体小到一定大小达到极限,不会继续减小,则始终跳不出循环,这时加一个class,让文字最后显示三个点。
注意:由于是单行文本,超出缩小字体到不能缩小的时候显示三个点,所以要默认给该行元素加一个class
.line_nowrap{
white-space:nowrap;
},
限定文本不换行,当字体缩小到一定大小,不能再缩小,依然超出的时候,添加 .lineClamp1 class,增加三个点,但此时由于加了不换行的属性,三个点是不能展示的,这时候还需要去掉不换行class.
这里有个疑问,亲测发现
Size减小的同时,size所在的div和size外层的div都会减小,所以这里用了
document.getElementById("titleBox").offsetWidth
来获取最新的文字所在的盒子宽度。
javascript实现一行文字随不同设备自适应改变字体大小至字数完全展示的更多相关文章
- javascript实现限定高度下文字随不同设备自适应改变字体大小至字数完全展示
function fontAutoMoreLine() { let textBox = document.getElementById("iconTxt"); let maxHei ...
- 改变字体大小实现自适应之js方案A
一.元素大小有两种写法 1.写结果:设计师给的移动端页面sketch设计稿一般是750px宽度,在sublime编辑器里,设置cssrem或rem-unit插件为56px的字体大小.做页面时,设计稿是 ...
- rem布局和使用js rem动态改变字体大小,自适应
解决rem文字动态改变字体大小: <script> console.log(window.devicePixelRatio); var iScale = 1; iScale = iScal ...
- javascript动画系列第四篇——拖拽改变元素大小
× 目录 [1]原理简介 [2]范围圈定 [3]大小改变[4]代码优化 前面的话 拖拽可以让元素移动,也可以改变元素大小.本文将详细介绍拖拽改变元素大小的效果实现 原理简介 拖拽让元素移动,是改变定位 ...
- delphi 程序窗体及控件自适应分辨率(通过ComponentCount遍历改变字体大小以及上下左右)
unit untFixForm; interface uses Classes, SysUtils, Controls, Forms; type TFontedControl = class(TCon ...
- 使用js rem动态改变字体大小,自适应
<html> <head> <meta charset="utf-8"> <script> console.log(window.d ...
- JavaScript动画-拖拽改变元素大小
▓▓▓▓▓▓ 大致介绍 拖拽改变元素大小是在模拟拖拽上增加了一些功能 效果:拖拽改变元素大小 ▓▓▓▓▓▓ 拖拽改变元素大小原理 首先这个方块得知道我们想要改变这个它的大小,所以我给它设定一个范围,当 ...
- 如何调整chm文字字体大小
chm文档是使用用层叠样式表来控制字符大小的,通过IE的改变“文字大小”是没效果的,那我们是不是就没有办法改变它的大小了呢?显然不是的. 工具/原料 chm文件 方法/步骤 首先打开chm ...
- 如何利用rem在移动端不同设备上让字体自适应大小
本人也是一个刚刚接触前端的小虾米,对于移动端这一块更是一抹眼的黑,前端时间接手开始一个移动端的项目,在网上查询了一下rem的作用,百度搜索下来全是介绍rem的作用原理的(rem是根据根元素计算的),然 ...
随机推荐
- Mysql 创建用户并授权
设置MySQL用户账号,指定哪个用户可以连接服务器,从哪里连接,连接后能做什么. MySQL管理员应该知道如何设置MySQL用户账号,指出哪个用户可以连接服务器,从哪里连接,连接后能做什么? GRAN ...
- git 删除分支 远程 && 本地
//查看远程分支 git branch -a //删除远程分支 git branch -r -d origin/branch-name git push origin :branch-name// 或 ...
- Saltstack 安装 命令
主机规划 10.0.0.21 master 10.0.0.22 minion 10.0.0.23 minion 基础环境 [root@10.0.0.21 ~]# cat /etc/redhat-rel ...
- Tomcat服务器配置https双向认证(使用keytool生成证书)
一,HTTPS原理 1,HTTP.HTTPS.SSL.TLS介绍与相互关系 (1)HTTP:平时浏览网页时候使用的一种协议.HTTP协议传输的数据都是未加密的(明文),因此使用HTTP协议传输隐私 ...
- 如何在IntelliJ IDEA中使用Git .ignore插件忽略不必要提交的文件
参考 https://blog.csdn.net/qq_34590097/article/details/56284935 最近初学Git,而且在使用的IDE是IntelliJ IDEA,发现IDE ...
- build.gradle最佳实践之buildConfigField
使用AndroidStudio进行开发,其中很重要的一个文件就是build.gradle,他是整个项目的控制中心,这里收集一些日常会用到的语法或者使用技巧,以备后用.这篇博客主要说明 buildTyp ...
- 微信小程序 多个视频播放器
大致思路就是,wx:for="{{ list }}"下两个view,一个视频video,另一个封面image(客户需求,要可以自定义封面).主要控制变量是playIndex,当点击 ...
- How to extract a complete list of extension types within a directory?
Open the PowerShell Tool and Run the below command: Get-Childitem "D:\testfolder\" -Recurs ...
- android开发之代码混淆
在${user.home}/project.properties文件中设置proguard.config属性 # To enable ProGuard to shrink and obfuscate ...
- hihocoder编程练习赛91:相邻字符串
题目链接 给定一个长度小于1e5的字符串s,s中字符全是大写英语字母.现在要寻找s中有多少组邻近的"hio"字符串,邻近的定义如下:hi距离+io距离+ho距离小于k.输入k和s, ...