html如何实现自适应字号
发表于:2024-11-17 作者:千家信息网编辑
千家信息网最后更新 2024年11月17日,小编给大家分享一下html如何实现自适应字号,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在开发过程中有遇到需要根据界面d
千家信息网最后更新 2024年11月17日html如何实现自适应字号
小编给大家分享一下html如何实现自适应字号,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
在开发过程中有遇到需要根据界面dom的宽高来设置自适应字号大小,现将开发思路分享
在页面dom元素的宽和高都有限制的情况下,无法为所有的元素设置同样的字号大小,而将字号设置过小又不利于界面美观,所以我开发的思路是通过JS来动态控制dom中的字号大小,即通过JS获取dom的宽度和高度,再将字号从12px开始累加,直到字号可以适应dom的宽高为止,最后得到的字号即为需要的字号
这里我是使用angularjs开发的,故将编写的指令贴出来以供参考
***.directive("doCalculateFontsize",['$timeout',function ($timeout) { /* * 通用的字体大小自适应,通过在改变字体大小的同时计算dom元素的宽高是否超界实现 * */ return function(scope, element, attr) { attr.$observe("doCalculateFontsize",function (interpolatedValue) { if(interpolatedValue!=undefined&&interpolatedValue!="") { var maxwidth = parseInt(attr.domMaxWidth); var maxheight = parseInt(attr.domMaxHeight); var th = parseInt(attr.domTotalHeight); var text = attr.doCalculateFontsize; var nowsize = 12; var maxsize = 200; angular.element(element).css("visibility", "hidden").html(text).css("font-size", nowsize + "px"); for (; nowsize < maxsize; nowsize++) { var nowwidth = angular.element(element)[0].offsetWidth; var nowheight = angular.element(element)[0].offsetHeight; if (nowwidth >= maxwidth || nowheight >= maxheight) { break; } else { angular.element(element).css("font-size", nowsize + "px").css("marginTop", (th - 0.5 * nowheight) + "px").css("visibility", "visible"); } } } else{ angular.element(element).css("visibility", "visible").html("").css("font-size", "12px"); } }) };}])
这里我是在字号累加之前将dom元素隐藏,在已经取得需要的字号以后再将dom元素设置可见,在本地测试时未发现有界面闪烁等异常,如界面需要处理的元素过多或者需要作定时刷新数据时,可能需要考虑页面的性能问题
需要注意的是,在css中需要对dom元素的样式做一些设置,如可能需要设置内容不换行、内容溢出、box-sizing等,根据实际情况自行设置
如果需要设置多个dom自适应字号时,也可以使用这个思路处理
以上是"html如何实现自适应字号"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
字号
元素
大小
内容
界面
开发
思路
篇文章
字体
情况
页面
参考
处理
美观
不怎么
动态
同时
多个
大部分
实际
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
涛思数据库创建用户
魔兽怀旧服不同服务器配置
幼儿园教案网络安全宣传周
下列属于数据库管理系统有
圣岛服务器怎么改成筛子
达梦数据库获取最后一条
软件开发里程碑 会计视野
数据库线下活动
网络技术专家王晓云
网络安全防护的运用
hp服务器进raid
拼多多软件开发多少钱
aws数据库迁移工具
公网云服务器k8s
软件开发的那些坑
计算机网络技术d是什么
人才数据库信息采集表的作用
杭州下城区学习软件开发
电脑服务器生产线生产厂家
扫脸支付软件开发
龙之谷怎么开新服务器
原神数据库如何用
网络安全技术基础的课后习题答案
数据库中的唯一标识
切实提高网络安全防范技能
如何做到网络安全绿色上网
mysq创建数据库用
维护网络安全主题宣传稿
外国关于网络安全的法律
最简单软件开发