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 相关文章推荐
编写Js代码要注意的几条规则
Sep 10 Javascript
flexigrid 参数说明
Nov 23 Javascript
SeaJS 与 RequireJS 的差异对比
Dec 08 Javascript
浅谈EasyUI中Treegrid节点的删除
Mar 01 Javascript
JavaScript和jQuery获取input框的绝对位置实现方法
Oct 13 Javascript
JavaScript数组和对象的复制
Mar 21 Javascript
js实现加载页面就自动触发超链接的示例
Aug 31 Javascript
Vue全局分页组件的实现代码
Aug 10 Javascript
简单了解JavaScript中的执行上下文和堆栈
Jun 24 Javascript
vue引用外部JS的两种种方法
Jan 28 Javascript
js cavans实现静态滚动弹幕
May 21 Javascript
Vue常用API、高级API的相关总结
Feb 02 Vue.js
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
php smarty的预保留变量总结
2008/12/04 PHP
php操作MongoDB基础教程(连接、新增、修改、删除、查询)
2014/03/25 PHP
如何修改Laravel中url()函数生成URL的根地址
2017/08/11 PHP
彻底搞懂PHP 变量结构体
2017/10/11 PHP
php从数据库中获取数据用ajax传送到前台的方法
2018/08/20 PHP
javascript操作文本框readOnly
2007/05/15 Javascript
javascript Ext JS 状态默认存储时间
2009/02/15 Javascript
js 数组克隆方法 小结
2010/03/20 Javascript
基于jquery用于查询操作的实现代码
2010/05/10 Javascript
一个小例子解释如何来阻止Jquery事件冒泡
2014/07/17 Javascript
js实例属性和原型属性示例详解
2014/11/23 Javascript
javascript实现图片循环渐显播放的方法
2015/02/24 Javascript
JavaScript中使用Callback控制流程介绍
2015/03/16 Javascript
基于jquery实现图片放大功能
2016/05/07 Javascript
Vue.js递归组件构建树形菜单
2017/12/24 Javascript
React中使用UEditor百度富文本的方法
2018/08/22 Javascript
4 种滚动吸顶实现方式的比较
2019/04/09 Javascript
安装多版本Vue-CLI的实现方法
2020/03/24 Javascript
Python下的twisted框架入门指引
2015/04/15 Python
详谈Python高阶函数与函数装饰器(推荐)
2017/09/30 Python
python的pandas工具包,保存.csv文件时不要表头的实例
2018/06/14 Python
Python Learning 列表的更多操作及示例代码
2018/08/22 Python
Jupyter notebook运行Spark+Scala教程
2020/04/10 Python
纯DOM+CSS3实现简单的小风车动画
2016/09/27 HTML / CSS
基于Jquery和Css3代码制作可以缩放的搜索框
2015/11/19 HTML / CSS
使用canvas一步步实现图片打码功能的方法
2019/06/17 HTML / CSS
VICHY薇姿美国官方网站:欧洲药房第一的抗衰老品牌
2017/11/22 全球购物
罗技美国官网:Logitech美国
2020/01/22 全球购物
别名指示符是什么
2012/10/08 面试题
《故乡》教学反思
2014/04/10 职场文书
领导班子三严三实心得体会
2014/10/13 职场文书
见习报告的格式
2014/10/31 职场文书
出差报告怎么写
2014/11/06 职场文书
员工自我评价范文
2015/03/11 职场文书
2015年度信用社工作总结
2015/05/04 职场文书
如何书写民事调解协议书?
2019/06/25 职场文书