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五图轮播切换实用版
Aug 17 Javascript
js获取元素相对窗口位置的实现代码
Sep 28 Javascript
鼠标悬浮显示二级菜单效果的jquery实现
Oct 29 Javascript
IE及IE6浏览器中判断JS文件加载成功失败的方法
Feb 18 Javascript
JS+HTML5 FileReader对象用法示例
Apr 07 Javascript
微信小程序实现弹出菜单功能
Jun 12 Javascript
JS实现用特殊符号替换字符串的中间部分区域的实例代码
Jul 24 Javascript
vuejs中监听窗口关闭和窗口刷新事件的方法
Sep 21 Javascript
了解JavaScript函数中的默认参数
May 30 Javascript
微信小程序 数据缓存实现方法详解
Aug 26 Javascript
jQuery实现可以扩展的日历
Dec 01 jQuery
用vue设计一个日历表
Dec 03 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中空字符串介绍0、null、empty和false之间的关系
2012/09/25 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(六)
2014/06/23 PHP
PHP树-不需要递归的实现方法
2016/06/21 PHP
详解在YII2框架中使用UEditor编辑器发布文章
2018/11/02 PHP
PHP超全局变量实现原理及代码解析
2020/09/01 PHP
jquery事件机制扩展插件 jquery鼠标右键事件。
2011/12/26 Javascript
js的.innerHTML = &quot;&quot;IE9下显示有错误的解决方法
2013/09/16 Javascript
jQueryMobile之Helloworld与页面切换的方法
2015/02/04 Javascript
javascript中Function类型详解
2015/04/28 Javascript
在Javascript中处理数组之toSource()方法的使用
2015/06/09 Javascript
浅谈window对象的scrollBy()方法
2015/07/15 Javascript
Nodejs爬虫进阶教程之异步并发控制
2016/02/15 NodeJs
第六章之辅组类与响应式工具
2016/04/25 Javascript
jquery点击改变class并toggle的实现代码
2016/05/15 Javascript
带有定位当前位置的百度地图前端web api实例代码
2016/06/21 Javascript
jQuery 选择器(61种)整理总结
2016/09/26 Javascript
jQuery plugin animsition使用小结
2017/09/14 jQuery
微信小程序分享海报生成的实现方法
2018/12/10 Javascript
通过cordova将vue项目打包为webapp的方法
2019/02/02 Javascript
elementUI table表格动态合并的示例代码
2019/05/15 Javascript
nodejs文件夹深层复制功能
2019/09/03 NodeJs
使用PDB简单调试Python程序简明指南
2015/04/25 Python
Python中的ConfigParser模块使用详解
2015/05/04 Python
Python读写ini文件的方法
2015/05/28 Python
Python中MySQLdb和torndb模块对MySQL的断连问题处理
2015/11/09 Python
python list格式数据excel导出方法
2018/10/31 Python
使用python3构建文件传输的方法
2019/02/13 Python
简单了解Django应用app及分布式路由
2019/07/24 Python
基于python分析你的上网行为 看看你平时上网都在干嘛
2019/08/13 Python
美国时尚女装在线:Missguided
2016/12/03 全球购物
教师自我鉴定范文
2013/11/10 职场文书
护理专业自我鉴定
2014/01/30 职场文书
项目总经理岗位职责
2014/02/14 职场文书
2015年五一劳动节慰问信
2015/03/23 职场文书
驳回起诉裁定书
2015/05/19 职场文书
新教师教学工作总结
2015/08/14 职场文书