产品提了一个小需求,希望一行能展示用户输入的所有文字,因为最多限制为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实现一行文字随不同设备自适应改变字体大小至字数完全展示的更多相关文章

  1. javascript实现限定高度下文字随不同设备自适应改变字体大小至字数完全展示

    function fontAutoMoreLine() { let textBox = document.getElementById("iconTxt"); let maxHei ...

  2. 改变字体大小实现自适应之js方案A

    一.元素大小有两种写法 1.写结果:设计师给的移动端页面sketch设计稿一般是750px宽度,在sublime编辑器里,设置cssrem或rem-unit插件为56px的字体大小.做页面时,设计稿是 ...

  3. rem布局和使用js rem动态改变字体大小,自适应

    解决rem文字动态改变字体大小: <script> console.log(window.devicePixelRatio); var iScale = 1; iScale = iScal ...

  4. javascript动画系列第四篇——拖拽改变元素大小

    × 目录 [1]原理简介 [2]范围圈定 [3]大小改变[4]代码优化 前面的话 拖拽可以让元素移动,也可以改变元素大小.本文将详细介绍拖拽改变元素大小的效果实现 原理简介 拖拽让元素移动,是改变定位 ...

  5. delphi 程序窗体及控件自适应分辨率(通过ComponentCount遍历改变字体大小以及上下左右)

    unit untFixForm; interface uses Classes, SysUtils, Controls, Forms; type TFontedControl = class(TCon ...

  6. 使用js rem动态改变字体大小,自适应

    <html> <head> <meta charset="utf-8"> <script> console.log(window.d ...

  7. JavaScript动画-拖拽改变元素大小

    ▓▓▓▓▓▓ 大致介绍 拖拽改变元素大小是在模拟拖拽上增加了一些功能 效果:拖拽改变元素大小 ▓▓▓▓▓▓ 拖拽改变元素大小原理 首先这个方块得知道我们想要改变这个它的大小,所以我给它设定一个范围,当 ...

  8. 如何调整chm文字字体大小

    chm文档是使用用层叠样式表来控制字符大小的,通过IE的改变“文字大小”是没效果的,那我们是不是就没有办法改变它的大小了呢?显然不是的. 工具/原料   chm文件 方法/步骤     首先打开chm ...

  9. 如何利用rem在移动端不同设备上让字体自适应大小

    本人也是一个刚刚接触前端的小虾米,对于移动端这一块更是一抹眼的黑,前端时间接手开始一个移动端的项目,在网上查询了一下rem的作用,百度搜索下来全是介绍rem的作用原理的(rem是根据根元素计算的),然 ...

随机推荐

  1. java中线程安全的map是ConcurrentHashMap

    原理:http://www.cnblogs.com/ITtangtang/p/3948786.html 与hashtable的区别:  http://blog.csdn.net/songfeihu08 ...

  2. unity中HideFlags的利用

    HideFlags主要用于控制物体在hierarchy,Inspector视图的显示销毁等的bit mask~ None:默认情况,正常可见对象~ API: HideInHierarchy:在Hier ...

  3. python测试开发django-45.xadmin添加小组件报错解决

    前言 xadmin首页上有个添加小组件按钮,打开的时候会报错"render() got an unexpected keyword argument 'renderer'" 环境: ...

  4. [Android Pro] https://blog.csdn.net/gaugamela/article/details/79143309

    原文地址:https://blog.csdn.net/gaugamela/article/details/79143309 最近遇到这样一个问题: 第三方的SDK除了Jar包外,还提供了对应的so文件 ...

  5. Android官方导航栏ActionBar(二)—— Action View、Action Provider、Navigation Tabs的详细用法

    在上一篇文章(Android之官方导航栏ActionBar)中,我们介绍了ActionBar各组成部分的基本应用.ActionBar除了提供Action Buttons外,还提供了多种导航方式如 Ac ...

  6. how to use boost program options

    From:  http://www.radmangames.com/programming/how-to-use-boost-program_options If it so happens that ...

  7. 移除list中null元素

    查询结果为null, list.size()却是1 移除该null元素 totalList.removeAll(Collections.singleton(null));

  8. PhoneGap-Android-HTML5-WebSocket

    https://github.com/FreakDev/PhoneGap-Android-HTML5-WebSocket

  9. 基于CentOS 搭建 Seafile 专属网盘

    系统要求:CentOS 7.2 64 位操作系统 安装 Seafile 安装依赖环境 使用 yum 安装 Python 及 MySQL: yum install python python-setup ...

  10. Boinx FotoMagico for Mac(电子相册制作工具)破解版安装

    1.软件简介    FotoMagico 是 macOS 系统上一款非常好用的电子视频相册制作工具,FotoMagico 被誉为 Mac 上的「会声会影」,我们可以使用这款软件快速的制作出精美的音乐视 ...