我刚刚使用了一些愚蠢的Javascript测试了一些浏览器:
function log_newline(msg, test_value) { if (!test_value) { test_value = document.getElementById('test').value; } console.log(msg + ': ' + (test_value.match(/r/) ? 'CR' : '') + ' ' + (test_value.match(/n/) ? 'LF' : ''));}log_newline('HTML source');log_newline('JS string', "foonbar");log_newline('JS template literal', `barbaz`);<textarea id="test" name="test"></textarea>Windows上使用IE8和Opera 9
rn。我测试过的所有其他浏览器(Windows上的Safari 4和Firefox
3.5,Linux上的Firefox
3.0)都使用
n。
n设置该值时,它们都可以很好地处理,尽管IE和Opera会在
rn内部将其再次转换回该值。有SitePoint文章,其中有更多详细信息,称为Java中的行尾。
还要注意,这与HTML文件本身中的实际行尾(
n与
rn给出相同的结果)无关。
提交表单时,所有浏览器都会以
%0D%0AURL编码规范化换行符。要看到这一点,请加载例如
data:text/html,<form><textareaname="foo">foo%0abar</textarea><inputtype="submit"></form>,然后按提交按钮。(某些浏览器阻止了已提交页面的加载,但是您可以在控制台中看到URL编码的表单值。)
不过,我认为您真的不需要做任何决定。如果只想在换行符上分割文本,则可以执行以下操作:
lines = foo.value.split(/rn|r|n/g);



