我正在尝试使用javascript从dbase打印文本字段,其中文本字段由php提供给具有id的textarea。 print javascript函数使用getElementById从textarea获取内容并打印它。但这是问题所在。要在textarea中正确显示,文本字段中会有换行符。这些在textarea中是不可见的。它们只是出现在换行符中。 (它们在dbase表中使用PHP管理员也是不可见的。它们也显示在那里作为换行符。)
但是,要在打印文本时显示换行符,需要将它们转换为<br>
。其他,你看,并打印一个runown句子。
我想我需要在javascript变量中搜索一些东西,也许\ n并替换为
但是,我似乎无法在打印页面中显示换行符(基于html。)
有人能建议正确的方法吗?感谢。
有缺陷的代码: JS ˚F
unction printit(id) {
var toprint = document.getElementById(id).innerHTML;
toprint = toprint.replace("\n","<br>");
win = window.open();
self.focus();
win.document.open();
win.document.write('<'+'html'+'><'+'head'+'><'+'style'+'>');
win.document.write('body, td { font-family: Verdana; font-size: 10pt;}');
win.document.write('<'+'/'+'style'+'><'+'/'+'head'+'><'+'body'+'>');
win.document.write(toprint);
win.document.write('<'+'/'+'body'+'><'+'/'+'html'+'>');
win.document.close();
win.print();
win.close();
}
HTML
<textarea id="textarea">A whole bunch
of text
with line breaks
goes here
</textarea><a href="javascript:void(0);" onclick="printit('textarea');">Print text</a>
答案 0 :(得分:1)
你可能只是替换了第一个换行符。尝试使用全局标志来替换它们:
toprint = toprint.replace(/\n/g, '<br />');
答案 1 :(得分:0)
我相信你需要它完全按照它出现在文本区域的方式打印出来。 textarea对其内容应用换行。这些不是换行符,不能替换。
在引用前将内容附加到与textarea 相同的宽度的元素。
即
...
win.document.write('<'+'/'+'style'+'><'+'/'+'head'+'><'+'body'+'>');
// element with same width as textarea
win.document.write('<div style="width: '+ document.getElementById(id).offsetWidth +'px">');
win.document.write(toprint);
win.document.write('</div>');
win.document.write('<'+'/'+'body'+'><'+'/'+'html'+'>');
...
答案 2 :(得分:0)
在HTML中显示换行符的最佳解决方案是使用CSS white-space 属性。