Text to Html

原创 2004年09月16日 10:31:00

  相信大家看到过Html<->Text转换的软件,自己编过这类转换软件的朋友可能也不少,工作中会也有可能会遇到。Html To Text无需多说,我在《TWebBrowser编程简述》一文中已有提及,我自己就过一个HtmlToText的软件,自我感觉界面还算不错(也许近期会发布)。方法很简单,使用来自IE & Delphi的TIEParser或者UILess单元,以IE作为HTML解码引擎,取得IHTMLDocument2接口,之后Body.OuterText中装的就是网页中的文本了,此处不再赘述。

  Text To Html呢?看来很简单,把文本放入一个TStringList,写几个函数,一行行地加上标记,遇到特殊字符转化一下就OK了。真的是这样吗?看了下面的例子就知道要做好并非如此简单。
  一个网上查询系统,有些文本文件每天都更新,需要原封不动地显示到IE的浏览器窗口上,由于不知道网页中对Tab如何处理,我就用8个空格来代替它,这样,对齐的时候麻烦就来了。因为文本文件来自不同的人员和不同的编辑器。有的人喜欢用Tab对齐,有的人喜欢用空格对齐,更有的一会儿用Tab一会儿用空格,要知道不同的编辑器对Tab的定义可能不同,有的是8个空格的位置,有的又只有5个,还有的(像Delphi)可以自定义。总之用我的方法显示出来是无法对齐的。
  怎么办?我想了各种方法,工作量都很大,而且不一定能起到很好的效果。把文本放在一个TextArea里面倒是没有问题,但显示出来显得很不规范。于是当时的解决办法是——放弃。

  很多天以后,我才又再次了解到了自己的浅薄,其实HTML语法规则指定时早已考虑到了这种情况,所以提供了一对标记“<PRE>”和“</PRE>”,在此标记包围中的文本均为格式化文本,空格和回车都会保留。于是Text To Html就变得很简单了,需要考虑的只是“<”符号,两步就搞定:
  1、使用StringReplace函数将需要转换的文本中所有的“<”符号替换为“&lt;”,避免文本中出现以“<>”包围的HTML标记文字的时候显示出错。StringReplace函数声明如下:

    type
     TReplaceFlags = set of (rfReplaceAll, rfIgnoreCase);
    function StringReplace(const S, OldPattern, NewPattern: string;
                Flags: TReplaceFlags): string;

  2、在文本首尾分别加上“<PRE>”和“</PRE>”即可(不要忘了一个空的网页需要的最基本元素)。

  试一试就知道,非常简单。

发表于“阿甘的家
2001年1月15日

HTML/CSS中文本text属性详解

letter-spacing:控制字母之间的距离 word-spacing :控制文字间空格的距离 text-decoration :控制文本是否有下划线 text-transform :控制英文的大...
  • xiaokangmiclong
  • xiaokangmiclong
  • 2016年03月30日 20:05
  • 3403

当<script>中的type等于text/html时,我们可以做很多事件!

我们可以在片断中定义一个被JS调用的代码,但代码又不在页面上显示,这时,我们可以使用下面的方法: 1 2 3 4 5 ...
  • xiangyong58
  • xiangyong58
  • 2016年01月29日 16:18
  • 1318

sublime text3快速生成html头部信息

经常见别人创建新的html文件时,直接在上面写上html:5,之后按了什么键就生成了html的头部文件。 网上搜索下,需要下载Emmet插件,按网上写的步骤按ctrl+shift+P打开命令面板,输...
  • sunshinegirl_7
  • sunshinegirl_7
  • 2015年11月12日 18:19
  • 28732

编辑JS和HTML,CSS的利器:Sublime Text 2.0.1 简体中文版

Sublime Text 是一个代码编辑器(Sublime Text 2是收费软件,但目前可以无限期试用)也是HTML和散文先进的文本编辑器。漂亮的用户界面和非凡的功能,例如迷你地图,多选择,Pyth...
  • changemyself
  • changemyself
  • 2013年03月06日 15:07
  • 8087

HTML :input text 的事件及方法

事件 描述 onactivate 当对象设置为活动元素时触发。 onafterupdate 当成功更新数据源对象中的关联对象后在数据绑定对象上触发。 onbeforeactivate 对象要被设置为当...
  • eric145
  • eric145
  • 2013年08月24日 13:46
  • 1918

【Web】Sublime Text 3常用插件安装

一、Sublime3下载 1.百度搜索Sublime3,选择进入下载页面   2.小编选择下载Win64位安装程序 二、Sublime3安装 傻瓜式安装,...
  • WHUZXQ
  • WHUZXQ
  • 2017年05月19日 12:44
  • 2851

通过js获取td标签的text、html、innerhtml三者的区别

注意innerhtml是原生的js的用法。 text、html是jQuery的用法,原生的js语法是没有text、html这种用法的。 原生的innerhtml = jQuery的...
  • Ideality_hunter
  • Ideality_hunter
  • 2017年04月19日 09:52
  • 3277

HTML :input text 的事件及方法

事件 描述 onactivate 当对象设置为活动元素时触发。 onafterupdate 当成功更新数据源对象中的关联对象后在数据绑定对象上触发。 onbeforeactivate 对象要被设...
  • li_zhenxing
  • li_zhenxing
  • 2014年11月20日 17:59
  • 2872

前端开发 sublime text 常用插件和配置

前端开发sublimeconfigmac配置此文件目录中文件主要是关于sublime的插件配置,快捷键配置,主题和字体配置。插件列表所有插件都可以使用Package Control安装,具体的安装方法...
  • yisuowushinian
  • yisuowushinian
  • 2016年01月07日 13:09
  • 21211

在HTML中实现动画的方法

Animation功能中实现动画的方法 方法 属性值的变化速度 linear 在动画开始与结束时以同样速度惊醒改变 ease-...
  • king_zxy
  • king_zxy
  • 2017年03月09日 16:59
  • 265
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Text to Html
举报原因:
原因补充:

(最多只允许输入30个字)