JavaScript 撑出页面文字换行


Posted in Javascript onJune 15, 2009

碰到一个问题,就是在页面展示的时候,很多情况下需要对显示的文字做折行处理,例如文字超过TD的宽度,或者DIV的宽度等等。
在IE下有word-break等等,但是在FF下,却是行不通,所以研究了一下,写了一个JS脚本,原理是这样的:
1. 首先,我们在页面上找一个span元素,用它来装载字符,然后通过它的宽度,来得到字符的显示宽度
2. 然后,我们在显示一个字符串的时候,就可以利用前面得到的字符宽度,计算出每个字符串的宽度
3. 在此基础上,计算出字符串应该折行的位置,插入<br/>进行折行就不是什么问题了。
条件所限,blog不能上传附件,我在这里解释一下代码。
代码有2部分,一个是“textWidth.js”,他完成绝大部分的工作;另外一个是测试页面。
1. textWidth.js

源代码 说明
var TextWidth = new function() { var widthLib = new Hash(); var textSpan; var self = this;  内部成员变量 widthLib是一个保存某个字体、字号的所有字符的宽度的hash表;
self.getWidth = function(string, fontName, fontSize) { var lib = getSizeLib(fontName, fontSize); var totalWidth = 0; for(var i =0; i 255) { totalWidth += lib[256]; }else{ totalWidth += lib[c]; } } return totalWidth; }  计算字符串的长度。算法简单,就是把每个字符的宽度都加到一起就好了。 关键是getSizeLib(fontName, fontSize);这个函数,如果Hash表里没有这个字体字号的宽度数据,它会主动初始化相应的宽度数据
self.wrapText = function(string, fontName, fontSize, maxWidth) { if (!string) { return " "; } var origText = string.strip(); var lib = getSizeLib(fontName, fontSize); var resultText = ""; var deltaW; var totalW = 0; for(var i =0; i 255) { deltaW = lib[256]; }else{ deltaW = lib[c]; } if ((totalW + deltaW) > maxWidth) { resultText += ""; totalW = deltaW; }else{ totalW += deltaW; } resultText += string.charAt(i); } return resultText; }  计算折行。这个也简单,先从Hash表里拿到宽度数据,然后逐个计算,宽度超了,就加个
进去
self.setSpan = function(obj) { textSpan = obj; textSpan.hide(); }  保存用于宽度计算的span元素
function getSizeLib(fontName, fontSize) { if (!widthLib.get(getKey(fontName, fontSize))) { initwidthLib(fontName, fontSize); } return widthLib.get(getKey(fontName, fontSize)); }  取得指定字体字号的宽度数据。没有的话,就初始化一份
function initwidthLib(fontName, fontSize) { var key = getKey(fontName, fontSize); var sizeLib = new Array(257); textSpan.show(); textSpan.style.fontFamily = fontName; textSpan.style.fontSize = fontSize+"px"; textSpan.update("中中中中中中中中中中"); sizeLib[256] = textSpan.offsetWidth/10; for(var i = 0; i  初始化
function getKey(fontName, fontSize) { return fontName+"@"+fontSize+"px"; } }  
   

下面是测试页面的代码

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1- 
transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<script language="javascript" src="prototype.js"></script> 
<script language="javascript" src="textWidth.js"></script> 
<title>无标题文档</title> 
<style type="text/css"> 
* { 
font-size: 14px; 
font-family: Geneva,Arial,Helvetica,sans-serif; 
} 
</style> 
</head> 
<body> 
<textarea id="in" type="text"></textarea><input type="button" value="test" onclick="runTest()"/><p/> 
<textarea id="resultSpan" style="width: 900px;font-size: 14px; font-family: Geneva"> 
</textarea> 
<div id="resultDisplay" style="font-size: 14px; font-family: Geneva;background-color:#e242E6; width:80px"></div> 
<span id="textSpan" style="display:none"></span> 
</body> 
<script type="text/javascript"> 
TextWidth.setSpan($('textSpan')); 
function runTest() { 
$('resultSpan').innerHTML = $("in").value; 
var theWidth = TextWidth.getWidth($('resultSpan').innerHTML, "Geneva", 14); 
$("resultDisplay").innerHTML = TextWidth.wrapText($('resultSpan').innerHTML, "Geneva", 14, 80); 
} 
</script> 
</html>

prototype.js请自行下载验证
Javascript 相关文章推荐
Javascript String.replace的妙用
Sep 08 Javascript
jquery自动切换tabs选项卡的具体实现
Dec 24 Javascript
jquery中对于批量deferred的处理方法
Jan 22 Javascript
js实现鼠标经过时图片滚动停止的方法
Feb 16 Javascript
javascript中对变量类型的判断方法
Aug 09 Javascript
深入学习jQuery Validate表单验证(二)
Jan 18 Javascript
javaScript知识点总结(必看篇)
Jun 10 Javascript
JS两种类型的表单提交方法实例分析
Nov 28 Javascript
JavaScrpt中如何使用 cookie 设置查看与删除功能
Jul 09 Javascript
最全正则表达式总结:验证QQ号、手机号、Email、中文、邮编、身份证、IP地址等
Aug 16 Javascript
vue实现手机号码抽奖上下滚动动画示例
Oct 18 Javascript
JavaScript组合设计模式--改进引入案例分析
May 23 Javascript
jquery.alert 弹出式复选框实现代码
Jun 15 #Javascript
论坛里点击别人帖子下面的回复,回复标题变成“回复 24# 的帖子”
Jun 14 #Javascript
FireFox JavaScript全局Event对象
Jun 14 #Javascript
Javascript 错误处理的几种方法
Jun 13 #Javascript
Javascript 学习书 推荐
Jun 13 #Javascript
javascript 框架小结 个人工作经验
Jun 13 #Javascript
动态刷新 dorado树的js代码
Jun 12 #Javascript
You might like
function.inc.php超越php
2006/12/09 PHP
php str_pad 函数使用详解
2009/01/13 PHP
PHP实现可自定义样式的分页类
2016/03/29 PHP
PHP实现的限制IP投票程序IP来源分析
2016/05/04 PHP
Fleaphp常见函数功能与用法示例
2016/11/15 PHP
php实现留言板功能
2017/03/05 PHP
详解PHP实现支付宝小程序用户授权的工具类
2018/12/25 PHP
js检测客户端不是firefox则提示下载
2007/04/07 Javascript
Jquery判断IE6等浏览器的代码
2011/04/05 Javascript
编写针对IE的JS代码两种编写方法
2013/01/30 Javascript
jQuery淡入淡出元素让其效果更为生动
2014/09/01 Javascript
js自动生成的元素与页面原有元素发生堆叠的解决方法
2014/09/04 Javascript
js简单抽奖代码
2015/01/16 Javascript
精通JavaScript的this关键字
2020/05/28 Javascript
jQuery购物车插件jsorder用法(支持后台处理程序直接转换成DataTable处理)
2016/06/08 Javascript
Node.js connect ECONNREFUSED错误解决办法
2016/09/15 Javascript
vue解决使用webpack打包后keep-alive不生效的方法
2018/09/01 Javascript
vue给对象动态添加属性和值的实例
2019/09/09 Javascript
前端 javascript 实现文件下载的示例
2020/11/24 Javascript
python字符串的方法与操作大全
2018/01/30 Python
对sklearn的使用之数据集的拆分与训练详解(python3.6)
2018/12/14 Python
PyQt5创建一个新窗口的实例
2019/06/20 Python
浅谈tensorflow之内存暴涨问题
2020/02/05 Python
Python读取xlsx数据生成图标代码实例
2020/08/12 Python
css3动画事件—webkitAnimationEnd与计时器time事件
2013/01/31 HTML / CSS
C#实现启动一个进程
2016/10/01 面试题
生日宴会答谢词
2014/01/09 职场文书
韩国商务邀请函
2014/01/14 职场文书
医科大学毕业生自荐信
2014/02/03 职场文书
公务员试用期满考核材料
2014/05/22 职场文书
销售提升方案
2014/06/07 职场文书
人力资源管理专业自荐书
2014/07/07 职场文书
党的群众路线教育实践活动督导组工作情况汇报
2014/10/28 职场文书
2014年社区计生工作总结
2014/11/18 职场文书
战友聚会致辞
2015/07/28 职场文书
四年级作文之植物
2019/09/20 职场文书