这应该很容易(至少似乎没有其他人遇到类似的问题),但我看不出它在哪里出问题。
我将 Markdown 文本存储在我的应用程序页面上输入的数据库中。使用 WMD 输入文本,实时预览看起来正确。
在另一个页面上,我正在检索降价文本并使用 Showdown.js 将其转换回 HTML 客户端进行显示。
假设我有这段文字:
The quick **brown** fox jumped over the *lazy* dogs.
1. one
1. two
4. three
17. four
我在我的 jQuery 文档就绪事件中使用这段 Javascript 来转换它:
var sd = new Attacklab.showdown.converter();
$(".ClassOfThingsIWantConverted").each(function() {
this.innerHTML = sd.makeHtml($(this).html());
}
我怀疑这是我的问题所在,但它几乎可以工作。
在 FireFox 中,我得到了我的预期:
敏捷的棕色狐狸跳过了懒惰的狗。
- 一
- 二
- 三
- 四
但在 IE(7 和 6)中,我得到了这个:
敏捷的棕色狐狸跳过了懒惰的狗。1. 一 1. 二 4. 三 17. 四
显然,IE 正在删除我的降价代码中的中断并将它们转换为空格。当我查看原始代码的源代码时(在脚本运行之前),容器 DIV 中存在中断。
我究竟做错了什么?
更新
它是由 IE innerHTML/innerText “怪癖”引起的,我之前应该在 ASP.Net 页面上使用数据绑定控件提到这一点 - 显然还有很多不同的解决方法。