我有以下HTML代码,它基本上复制了一个文本区域框,包括它的文本。
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Test Page</title>
<script type="text/javascript">
function copyTextarea() {
var originalTextbox = document.getElementById('originalTextarea');
var copiedTextboxSpan = document.getElementById('copiedTextareaSpan');
var text = originalTextbox.value;
copiedTextboxSpan.innerHTML = '<textarea name="myNewTextarea" rows="5" cols="50"></textarea>';
var newTextbox = document.getElementsByName('myNewTextarea')[0];
newTextbox.innerHTML = text;
}
</script>
</head>
<body>
Enter your text:
<br />
<textarea id="originalTextarea" rows="5" cols="50"></textarea>
<br />
<input type="button" value="Copy Textarea" onclick="copyTextarea()" />
<br />
Copied text:
<br />
<span id="copiedTextareaSpan"></span>
</body>
</html>
这是一个非常简化的HTML版本,所以请不要建议巨大的变化。我需要创建文本区域框,并单独设置其文本,等等。
这段代码看起来很简单,工作得很好,除了换行符。由于某些原因,Internet Explorer (IE)总是将换行符转换为单个空格。更奇怪的是,这并没有在我的Tomcat服务器本地发生,而是在我部署到测试服务器时悄悄发生的。但在测试服务器上,它在Chrome, Firefox等中运行良好。
有人知道可能会发生什么吗?我不太了解JavaScript,但我认为执行代码的是浏览器。但如果这是真的,为什么IE在本地没有问题,但在测试服务器上有问题?
尝试创建实际的DOM对象:
newTextarea = document.createElement('textarea');
newTextarea.setAttribute('name', 'myNewTextarea');
newTextarea.setAttribute('rows', '5');
newTextarea.setAttribute('cols', '50');
copiedTextboxSpan.appendChild(newTextarea);
var newTextbox = document.getElementsByName('myNewTextarea')[0];
newTextbox.value = text;
另外,在处理文本区域时使用value
而不是innerHTML
。
如果你可以使用jQuery:
$('#copiedTextareaSpan').replaceWith(function () {
var text = $('#originalTextarea').val();
return '<textarea name="myNewTextarea" rows="5" cols="50">' + text + '</textarea>';
});
将originalTextarea
的文本复制到copiedTextArea
(创建后)。