PHP / JS;将不可见的换行符或换行符转换为html标记以进行打印

时间:2012-12-26 16:17:37

标签: javascript printing newline

我正在尝试使用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>

3 个答案:

答案 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 属性。