整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

聊一聊java程序中的换行符,你用对了吗

见的换行符

Java程序中的换行符一般使用“\n”表示,它是一个转义字符,表示换行符。根据操作系统的不同,换行符的实际表示可能不同:

  • 在Windows系统中,换行符由两个字符“\r\n”表示,即回车符和换行符。
  • 在Unix/Linux系统中,换行符只由一个字符“\n”表示,即换行符。
  • 在Mac OS Classic(Mac OS 9及之前版本)中,换行符只由一个字符“\r”表示,即回车符。

因此,为了使Java程序的换行符在不同的操作系统上都能正确识别,可以使用Java提供的

System.lineSeparator()方法获取当前系统的换行符。该方法会返回一个字符串,表示当前系统的换行符。

\r\n和\n的区别

\r和\n都是字符,分别表示回车符和换行符。

在Windows系统中,使用回车符和换行符组合来表示一行的结束,即行尾是“\r\n”。而在Unix/Linux系统中,一行的结束只需要使用换行符“\n”即可。

这种区别的历史原因是因为早期的打印机和终端设备使用不同的方式表示一行的结束,有些设备只使用回车符,有些设备只使用换行符。随着计算机技术的发展,这种区别逐渐被统一。

在Java程序中,为了保证跨平台的兼容性,可以使用System.lineSeparator()方法获取当前系统的换行符,而不是直接使用"\r\n"或"\n"。这样可以确保Java程序在任何操作系统下都能正确地处理换行符

换行符的解析

如果一串字符里面有换行符,可以使用Java中的BufferedReader类来逐行读取并解析这些字符。

具体实现方法是,首先将这串字符封装成一个StringReader对象,然后再将其作为参数创建一个BufferedReader对象。接下来,可以使用BufferedReader对象的readLine()方法逐行读取这些字符,并对每一行进行解析。

以下是一个示例代码:


String input = "Hello\nworld\n!";

try (BufferedReader reader = new BufferedReader(new StringReader(input))) {
    String line;
    while ((line = reader.readLine()) != null) {
        // 对每一行进行解析
        System.out.println(line);
    }
} catch (IOException e) {
    e.printStackTrace();
}
复制代码

在上面的代码中,我们首先将字符串“Hello\nworld\n!”封装成一个StringReader对象,并将其作为参数创建一个BufferedReader对象。然后,使用BufferedReader对象的readLine()方法逐行读取字符串,并输出每一行。

BufferedReader的readLine()方法可以正常解析使用"\r\n"作为换行符的字符串,因为该方法在解析时会自动识别并处理不同的换行符,包括"\n"、"\r"、"\r\n"等。

例如,如果输入的字符串是这样的:

String input = "Hello\r\nworld\r\n!";
复制代码

使用以下代码可以正确地解析每一行:

try (BufferedReader reader = new BufferedReader(new StringReader(input))) {
    String line;
    while ((line = reader.readLine()) != null) {
        // 对每一行进行解析
        System.out.println(line);
    }
} catch (IOException e) {
    e.printStackTrace();
}
复制代码

在实际应用中,如果字符串中的换行符不确定,可以使用Java提供的System.lineSeparator()方法获取当前操作系统的换行符,以保证程序的兼容性。例如:

String input = "Hello" + System.lineSeparator() + "world" + System.lineSeparator() + "!";

try (BufferedReader reader = new BufferedReader(new StringReader(input))) {
    String line;
    while ((line = reader.readLine()) != null) {
        // 对每一行进行解析
        System.out.println(line);
    }
} catch (IOException e) {
    e.printStackTrace();
}
复制代码

上面的代码中,我们使用System.lineSeparator()方法获取当前操作系统的换行符,并将其与其他字符串拼接在一起,以保证程序的兼容性。

前端如何处理换行

前端在处理字符串换行时,也可以使用类似的思路,即使用特定的换行符来代表一行的结束,并在解析时进行处理。

在前端中,通常使用"\n"作为换行符来处理,因为在Web开发中,"\n"是HTML和CSS中表示换行的标准方式。此外,在前端处理字符串时,也可以使用JavaScript中的String.prototype.split()方法将字符串按照换行符分割成多行,并对每一行进行解析和处理。

以下是一个示例代码:

javascriptCopy codeconst input = "Hello\nworld\n!";
const lines = input.split("\n");

for (let i = 0; i < lines.length; i++) {
  // 对每一行进行解析和处理
  console.log(lines[i]);
}
复制代码

在上面的代码中,我们首先使用String.prototype.split()方法将字符串按照换行符"\n"分割成多行,并将每一行保存到一个数组中。然后,使用for循环对每一行进行解析和处理,并将解析结果输出到控制台。

小结

  1. 在Java程序中,为了保证跨平台的兼容性,可以使用System.lineSeparator()方法获取当前系统的换行符,而不是直接使用"\r\n"或"\n"。这样可以确保Java程序在任何操作系统下都能正确地处理换行符
  2. 在Web开发中,由于不同的操作系统和浏览器可能会对换行符的处理方式有所不同,因此在处理字符串时,最好使用标准的"\n"作为换行符,以保证程序的兼容性


原文链接:https://juejin.cn/post/7212548256944341050

标签是默认是自动换行的,因此设置好宽度之后,能够较好的实现效果,但是最近的项目中发现,使用ajax加载数据之后,p标签内的内容没有换行,导致布局错乱,于是尝试着使用换行样式,虽然解决了问题,但是并没有发现本质原因,本质在于,我当时获取的数据是一长串的数字,浏览器应该是对数字和英文单词处理方式相近,不会截断。

先给出各种方式,再具体介绍每一个属性。

强制不换行

p { white-space:nowrap; }

自动换行

p { word-wrap:break-word; }

强制英文单词断行

p { word-break:break-all; }

*注意:设置强制将英文单词断行,需要将行内元素设置为块级元素。

超出显示省略号

p{text-overflow:ellipsis;overflow:hidden;}

white-space: normal|pre|nowrap|pre-wrap|pre-line|inherit;

white-space 属性设置如何处理元素内的空白

normal 默认。空白会被浏览器忽略。

pre 空白会被浏览器保留。其行为方式类似 HTML 中的 pre 标签。

nowrap 文本不会换行,文本会在在同一行上继续,直到遇到 br 标签为止。

pre-wrap 保留空白符序列,但是正常地进行换行。

pre-line 合并空白符序列,但是保留换行符。

inherit 规定应该从父元素继承 white-space 属性的值。

word-wrap: normal|break-word;

word-wrap 属性用来标明是否允许浏览器在单词内进行断句,这是为了防止当一个字符串太长而找不到它的自然断句点时产生溢出现象。

normal: 只在允许的断字点换行(浏览器保持默认处理)

break-word:在长单词或URL地址内部进行换行

word-break: normal|break-all|keep-all;

word-break 属性用来标明怎么样进行单词内的断句。

normal:使用浏览器默认的换行规则。

break-all:允许再单词内换行

keep-all:只能在半角空格或连字符处换行

举例看起区别:

<!doctype html>

<html lang="en">

<head>

<!--网站编码格式,UTF-8 国际编码,GBK或 gb2312 中文编码-->

<meta http-equiv="content-type" content="text/html;charset=utf-8" />

<meta name="Keywords" content="关键词一,关键词二">

<meta name="Description" content="网站描述内容">

<meta name="Author" content="Yvette Lau">

<title>Document</title>

<!--css js 文件的引入-->

<style>

.word{background:#E4FFE9;width:250px;margin:50px auto;padding:20px;font-family:"microsoft yahei";}

/* 强制不换行 */

.nowrap{white-space:nowrap;}

/* 允许单词内断句,首先会尝试挪到下一行,看看下一行的宽度够不够,

不够的话就进行单词内的断句 */

.breakword{word-wrap: break-word;}

/* 断句时,不会把长单词挪到下一行,而是直接进行单词内的断句 */

.breakAll{word-break:break-all;}

/* 超出部分显示省略号 */

.ellipsis{text-overflow:ellipsis;overflow:hidden;}

</style>

</head>

<body>

<div class = "word">

<p class = "nowrap">wordwrap:breakword;absavhsafhuafdfbjhfvsalguvfaihuivfs</p>

<p class = "breakword">wordwrap:break-word;absavhsafhuafdfbjhfvsalguvfaihui</p>

<p class = "breakAll">wordwrap:break-word;absavhsafhuafdfbjhfvsalguvfaihuivf</p>

<p class = "normal">wordwrap:breakword;absavhsafhuafdfbjhfvsalguvfaihuivfsa</p>

<p class = "ellipsis">wordwrap:breakword;absavhsafhuafdfbjhfvsalguvfaihuivfsab</p>

</div>

</body>

</html>

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33

效果如下:

端--输入框换行,高度自适应

最近项目遇到一个说小不小说大不大的问题,输入框要自动换行,并且高度还得自适应,我试了几种方式,

1.input 输入,input不能换行,上网查询了说将css设为word-break: break-all; word-wrap:break-word;也是无效的。

2.div 设置contenteditable="true"属性,这种方法可以实现输入内容自动换行,并且自适应高度,但是项目需要光标从边输入,我试过text-align:right是无效的。所以这种方式也不行。

3.textarea,文本输入框,想想这个应该可以了吧,文本输入框是可以内容自动换行,可是高度怎么都是固定的啊。我还是没解决。百度吧,终于找到解决办法啦。

最后遇到一个光标在placeholder提示文字上面,解决办法:#textarea::-webkit-input-placeholder{ padding-right: 4px;}

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title></title>

<style>

#textarea {

display: block;

margin:0 auto;

overflow: hidden;

width: 550px;

font-size: 14px;

height: 18px;

line-height: 24px;

padding:2px;

text-align: right;

}

textarea {

outline: 0 none;

border-color: rgba(82, 168, 236, 0.8);

box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1), 0 0 8px rgba(82, 168, 236, 0.6);

}

</style>

</head>

<body>

<textarea id="textarea" placeholder="回复内容"></textarea>

<script>

var autoTextarea = function (elem, extra, maxHeight) {

extra = extra || 0;

var isFirefox = !!document.getBoxObjectFor || 'mozInnerScreenX' in window,

isOpera = !!window.opera && !!window.opera.toString().indexOf('Opera'),

addEvent = function (type, callback) {

elem.addEventListener ?

elem.addEventListener(type, callback, false) :

elem.attachEvent('on' + type, callback);

},

getStyle = elem.currentStyle ? function (name) {

var val = elem.currentStyle[name];

if (name === 'height' && val.search(/px/i) !== 1) {

var rect = elem.getBoundingClientRect();

return rect.bottom - rect.top -

parseFloat(getStyle('paddingTop')) -

parseFloat(getStyle('paddingBottom')) + 'px';

};

return val;

} : function (name) {

return getComputedStyle(elem, null)[name];

},

minHeight = parseFloat(getStyle('height'));

elem.style.resize = 'none';

var change = function () {

var scrollTop, height,

padding = 0,

style = elem.style;

if (elem._length === elem.value.length) return;

elem._length = elem.value.length;

if (!isFirefox && !isOpera) {

padding = parseInt(getStyle('paddingTop')) + parseInt(getStyle('paddingBottom'));

};

scrollTop = document.body.scrollTop || document.documentElement.scrollTop;

elem.style.height = minHeight + 'px';

if (elem.scrollHeight > minHeight) {

if (maxHeight && elem.scrollHeight > maxHeight) {

height = maxHeight - padding;

style.overflowY = 'auto';

} else {

height = elem.scrollHeight - padding;

style.overflowY = 'hidden';

};

style.height = height + extra + 'px';

scrollTop += parseInt(style.height) - elem.currHeight;

document.body.scrollTop = scrollTop;

document.documentElement.scrollTop = scrollTop;

elem.currHeight = parseInt(style.height);

};

};

addEvent('propertychange', change);

addEvent('input', change);

addEvent('focus', change);

change();

};

</script>

<script>

var text = document.getElementById("textarea");

autoTextarea(text);// 调用

</script>

</body>

</html>