博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
怎么能正常显示多行文本呢?
阅读量:4224 次
发布时间:2019-05-26

本文共 2160 字,大约阅读时间需要 7 分钟。

谁来教教我??

唔唔唔。。。

网页中用TextBox让用户输入文本,然后存入数据库,再从数据库中读出显示在页面上。常常这样做会遇到不少问题,因为TextBox实际上是一个Windows组件,和网页显示标记如:<p>,<td>,<div>等,对字符的解析方法是不同的。比如前者的换行标记为“/r/n”,而后者为“<br>”。这就带来一个转换的问题。

  在做转换之前,先来考虑几个问题:

  1、 TextBox用“/r/n”来标记换行而网页中以“<br>”标记

  2、 网页中连续的空格当做一个空格处理,比如“a b    c”将会显示“a b c”

  3、 用户输入特殊字符比如:“<”,“&”,“&nbsp;”,“&lt;”,这些都是网页中有特殊意义的字符,会被解析,而用户输入的目的当然遣幌M唤馕觥?/P>

  现在来解决这几个问题,有一种解决办法是在显示的时候仍然用TextBox去显示,这样就不用做任何转换,只要把TextBox.ReadOnly设为true,这样在一定程度上能满足要求。但是往往为了网页的美观,这样做是不可取的。比较好的办法是去解析用户输入的字符串,可以做这样的转换:

  第一步:

  “<”      à“&lt;”

  “&”      à“&amp;”

  “&nbsp;”à“&amp;nbsp;”

  ……(此处的省略号后文有说明)

  第二步:

  “ ”      à“&nbsp;”

  “/r/n”  à“<br>”

  这里必须分两步转换,因为如果你先做第二步转换的话混把用户输入的特殊字符串和由转换而的的特殊字符串混淆,比如:

  用户输入:a b   c&nbsp;d

  第二步转换:a&nbsp;b&nbsp;&nbsp;&nbsp;c&nbsp;d

  第一步转换:a&amp;nbsp;b&amp;nbsp;&amp;nbsp;&amp;nbsp;c&amp;nbsp;d

  可以看到,经过第一次转换后已经无法分辨用户输入的“&nbsp;”和转换而来的“&nbsp;”,在做第二次转换的时候就会统一处理就会出错。结果显示:a&nbsp;b&nbsp;&nbsp;&nbsp;c&nbsp;d

  如果严格按照第一步,第二步的转换顺序来转换就不会出现这个问题。

  把转换后的字符串存入数据库,在显示的时候直接把从数据库读出的字符串给HTML组件赋值,比如:

  //这里假设temp是从数据库中读出来的,这里演示Table和HtmlTable其他的控件类似

  //显示的效果是:<a b

  //Table1是Web控件

  String temp = “&lt;a&nbsp;b”;

  Table1.Rows[0].Cells[0].Text = temp;

  //Table2是HTML控件

  Table2.Rows[0].Cells[0].InnerHtml = temp;

HtmlTable有两个相似的属性“InnerHtml”,“InnerText”,介绍一下这两个属性的区别:

  InnerHtml:显示的时候会对传入的值进行HTML解析,就像上面的例子。

  InnerText:显示的时候不会对传入的值新型解析,直接把传入的值显示出来。比如把上面的例子改成:Table2.Rows[0].Cells[0].InnerText = temp;那么显示的效果将会变成:&lt;a&nbsp;b

  虽然这两个属性用起来很方便,似乎可以满足平时的使用需求,但是InnerText有两个问题:

  1、 无法标记换行,不管是“/r/n”还是“<br>”都不是换行标记

  2、 连续的空格仍然只显示一个空格。

  所以想不转换字符串而直接用InnerText是不可取的。但是皇歉龇浅7彼龅墓蹋蛭狧TML的特殊标记非常多。值得庆幸的是ASP.NET提供了HttpServerUtil类,该类提供了HtmlEncode()和HtmlDecode()方法,这里我们只用到HtmlEncode()方法。我们就可以这样来转换:

  //“/r/n”在TextBox中硬回车的时候会自动添上

  string temp = “a b   c&nbsp;d/r/ne<”;

  //Server是Page类的一个属性,也就是说任何aspx页面的codebehind中都是可以使用的

  //因为aspx页面都是继承Page类的。

  temp = Server.HtmlEncode(temp);

  temp = temp.Replace(" ","&nbsp;");

  temp = temp.Replace("/r/n","<br>");

  Table1.Rows[0].Cells[0].Text = temp;

  Table2.Rows[0].Cells[0].InnerHtml = temp;

  //显示效果:a b   c&nbsp;d

  //        e<

  到这里你也许会想一个问题,万一用户输入“/r/n”怎么办?不用担心,网页组件的设计者已经考虑到了这个问题,因为用户输入的“/r/n”会被自动转换成“//r//n”(当然在我们做转换之前)。

  大功告成:)

转载地址:http://tlgmi.baihongyu.com/

你可能感兴趣的文章
清华成果发布 | 广度学习基础计算系统集成平台
查看>>
修改代码150万行!Apache Flink 1.9.0做了这些重大修改!(附链接)
查看>>
2019研究生新生大数据出炉!清华园迎来8900多名新主人
查看>>
在刚刚结束的ACL 2019上,知识图谱领域都发生了哪些大事?
查看>>
GitHub 上有什么好玩的项目?(附地址)
查看>>
独家|使用Python进行机器学习的假设检验(附链接&代码)
查看>>
跨学科整合,打造大数据最强集团军:清华大学大数据能力提升项目宣讲会来了!...
查看>>
报名 | 智进未来:AI在医疗健康领域的应用、挑战及发展趋势
查看>>
10行代码带你搞定目标检测(附代码)
查看>>
包教包会!7段代码带你玩转Python条件语句(附代码)
查看>>
数据分析必备:掌握这个R语言基础包1%的功能让你事半功倍!(附代码)
查看>>
近期活动盘点:智进未来:AI在医疗健康领域的应用、挑战及发展趋势
查看>>
158行Python代码复现:DeepMind提图像生成的递归神经网络DRAW
查看>>
报名 | AI TIME 6 论道机器翻译——离我们还有多远?
查看>>
清华发布新版计算机学科推荐学术会议和期刊列表,与CCF有何不同?(附链接)...
查看>>
报名 | 2019清华大数据系统软件峰会
查看>>
清华90后女学霸范楚楚将加入MIT任助理教授,面试宝典分享!
查看>>
数据蒋堂 | 数据压缩手段
查看>>
ACL 2019 | 理解 BERT 每一层都学到了什么
查看>>
近期活动盘点:2019清华大数据系统软件峰会(9.15)
查看>>